МИНОБРНАУКИ РОССИИ

Государственное образовательное учреждение

высшего профессионального образования

**«Санкт-Петербургский государственный электротехнический университет «ЛЭТИ» им.В.И.Ульянова (Ленина)» (СПбГЭТУ)**

Кафедра математического обеспечение и применения ЭВМ

В. А. КИРЬЯНЧИКОВ

Доцент кафедры МОЭВМ

**Архитектура компьютера**

Учебное пособие

Санкт-Петербург

2016

Оглавление

[1 Основные понятия архитектуры и организации компьютеров. 4](#_Toc479439742)

[1.1. Состав компьютера 4](#_Toc479439743)

[1.2. Виды (классы) компьютеров 4](#_Toc479439744)

[1.3. Принцип программного управления и машина фон Неймана 5](#_Toc479439745)

[1.4. Понятия архитектуры, организации и реализации компьютера 5](#_Toc479439746)

[1.5. Многоуровневая организация компьютера 6](#_Toc479439747)

[1.6. Понятие семантического разрыва между уровнями 6](#_Toc479439748)

[1.7. Организация аппаратных средств ВМ 7](#_Toc479439749)

[2 Представление и обработка данных в ВМ 9](#_Toc479439750)

[2.1. Целые числа……………………………………………………………………………………………………...9](#_Toc479439751)

[2.2. Представление и обработка вещественных чисел…………………………………………………………...10](#_Toc479439752)

[2.3. Логические операции над битовыми наборами……………………………………………………………...11](#_Toc479439753)

[2.4. Представление и обработка символов………………………………………………………………………...12](#_Toc479439754)

[2.5. Представление видеоинформации и аудиоинформации……………………………………………………..12](#_Toc479439755)

[3 Организация процессора и основной памяти ВМ 13](#_Toc479439756)

[3.1. Типовая структура процессора и основной памяти 13](#_Toc479439757)

[3.2. Основной цикл работы процессора 14](#_Toc479439758)

[3.3. Организация процессора и памяти в архитекуре Intel X86*.* 15](#_Toc479439759)

[3.3.1. Программно доступные регистры процессора 15](#_Toc479439760)

[3.3.2. Организация стека в архитектуре Intel Х86 16](#_Toc479439761)

[3.3.3. Организация выполняемых программ в MS DOS 16](#_Toc479439762)

[3.3.4. Режимы адресации памяти в архитектуре Intel Х86 17](#_Toc479439763)

[3.3.5. Краткая характеристика системы команд процессоров Intel Х86 19](#_Toc479439764)

[3.3.6 .Арифметическая обработка чисел с использованием математического сопроцессора 19](#_Toc479439765)

[3.3.7. Организация прерываний в процессорах Intel X86 21](#_Toc479439766)

[3.3.8. Эволюция микроархитектуры Intel X86 24](#_Toc479439767)

[4. Управление выполнением команд в компьютерах. 25](#_Toc479439768)

[4.1. Аппаратный способ формирования управляющих сигналов……………………………………………….26](#_Toc479439769)

[4.2. Микропрограммный способ формирования управляющих сигналов……………………………………...27](#_Toc479439770)

[5. Компьютеры с сокращенным набором команд 30](#_Toc479439771)

[6. Организация памяти в компьютере 34](#_Toc479439772)

[6.1. Назначение и основные характеристики памяти 34](#_Toc479439773)

[6.2. Основные среды хранения информации 34](#_Toc479439774)

[6.3. Методы доступа к данным. 35](#_Toc479439775)

[6.4. Память с произвольным доступом (ППД) 35](#_Toc479439776)

[6.5. Блочная организация основной памяти………………………………………………………………………36](#_Toc479439777)

[6.6. Постоянные запоминающие устройства (ПЗУ - ROM)……………………………………………………...37](#_Toc479439778)

[6.7. Ассоциативные запоминающие устройства (АЗУ)………………………………………………………….37](#_Toc479439779)

[6.8. Иерархическая система памяти 38](#_Toc479439780)

[6.9. Организация кэш-памяти……………………………………………………………………………………...39](#_Toc479439781)

[6.10. Организация виртуальной памяти 42](#_Toc479439782)

[6.11. Организация виртуальной памяти в Intel 80386 и более старших моделях. 44](#_Toc479439783)

[6.12. Защита памяти в процессоре Intel 80386 46](#_Toc479439784)

[*7.* Организация работы с внешней памятью 47](#_Toc479439785)

[7.1. Типы, виды, свойства дисковых накопителей информации…………………………………………………47](#_Toc479439786)

[7.2. Магнитные дисковые накопители……………………………………………………………………………..47](#_Toc479439787)

[7.3. Основные физические и логические параметры ЖМД……………………………………………………...48](#_Toc479439788)

[7.4. Контроллеры жестких дисков………………………………………………………………………………….49](#_Toc479439789)

[7.5. Логическое хранение и кодирование информации…………………………………………………………..49](#_Toc479439790)

[7.6. Интерфейсы жестких дисков…………………………………………………………………………………..51](#_Toc479439791)

[7.7. Работа накопителя………………………………………………………………………………………………51](#_Toc479439792)

[7.8. Внешняя память на CD и DVD дисках……………………………………………………………………….52](#_Toc479439793)

[8. Принципы организации RAID массивов………………………………………………………………54](#_Toc479439794)

[8.1. Основные принципы построения RAID массивов…………………………………………………………..54](#_Toc479439795)

[8.2. Одиночные уровни RAID……………………………………………………………………………………...55](#_Toc479439796)

[8.3. Составные уровни RAID массивов……………………………………………………………………………59](#_Toc479439797)

[8.4. Сравнительные результаты 61](#_Toc479439798)

[9. Системные и локальные шины 62](#_Toc479439799)

[9.1. Общие положения и требования к шинам 62](#_Toc479439800)

[9.2. Основные виды, характеристики и параметры шин………………………………………………………….63](#_Toc479439801)

[9.3. Стандарты шин 65](#_Toc479439802)

[10. Организация системы ввода-вывода в ВМ 69](#_Toc479439803)

[10.1. Назначение и основные требования к системе ввода-вывода ВМ 69](#_Toc479439804)

[10.2. Архитектура систем ввода-вывода 69](#_Toc479439805)

[10.3. Способы выполнения операции передачи данных 71](#_Toc479439806)

[10.4. Структуры контроллеров ВУ для различных режимов передачи данных 73](#_Toc479439807)

[11. Программные средства управления вводом-выводом (ПС УВВ) 75](#_Toc479439808)

[11.1. Состав ПС УВВ 75](#_Toc479439809)

[11.2. Основные компоненты процедуры управления ввода-вывода общего вида 76](#_Toc479439810)

[11.3 Состав и реализация устанавливаемого драйвера символьного типа 76](#_Toc479439811)

[Список литературы 80](#_Toc479439812)

[ПРИЛОЖЕНИЯ 81](#_Toc479439813)

# Основные понятия архитектуры и организации компьютеров.

# *1.1. Состав компьютера*

**Компьютер** или **вычислительная машина (**ВМ)– это совокупность аппаратных и программных средств, предназначенных для обработки информации. ВМ обычно содержит один основной процессор и, возможно, несколько сопроцессоров, имеет фиксированный состав и универсальное применение. **Вычислительные системы** (ВС), в отличие от ВМ, содержат несколько процессоров, имеют переменный состав и являются проблемно-ориентированными (специализированными). Состав аппаратных и программных средств компьютера можно пояснить с помощью рис. 1.1.

![](data:image/x-emf;base64,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)

Процессор – основное устройство управления и обработки данных. Память – набор устройств для хранения информации, используемой в процессе работы машины. Внешние устройства обеспечивают взаимодействие машины с внешней средой (в том числе с пользователями). Шины связи и протоколы взаимодействия реализуют физическую среду и алгоритмы обмена данными между различными устройствами.

Операционные системы - являются основными средствами управления выполнением программ и распределения ресурсов машины между процессами. Инструментальные ПС (программные среды) включают все средства, необходимые для разработки программ: редакторы, компиляторы, отладчики и др. Системы промежуточного ПО (Middleware) – ИТС (инструментальные технологические среды) – позволяют реализовать определенную технологию разработки программных средств: COM, DCOM, CORBA, RMI и др. Проблемно-ориентированные ПС предназначены для решения задач определенной области применения: MathLab (научные вычисления), AutoCAD (конструирование), PhotoShop (графический редактор), 3D Studio (машинная графика) и др. Утилиты – сервисные средства, облегчающие взаимодействия пользователя с компьютером: архиваторы, программы форматирования, антивирусные программы и др.

# *1.2. Виды (классы) компьютеров*

В настоящее время распространены следующие классы компьютеров:

- микрокомпьютеры – встраиваемые микропроцессоры со специальным ПО, используемые как программируемые контроллеры для промышленного оборудования (Embedded Computer); с середины 1990-х г.г. широкое распространение получили процессоры архитектуры ARM (Advanced RISC Machines), используемые в [смартфонах](http://ru.wikipedia.org/wiki/%D0%A1%D0%BC%D0%B0%D1%80%D1%82%D1%84%D0%BE%D0%BD),  [интернет-планшетах](http://ru.wikipedia.org/wiki/%D0%98%D0%BD%D1%82%D0%B5%D1%80%D0%BD%D0%B5%D1%82-%D0%BF%D0%BB%D0%B0%D0%BD%D1%88%D0%B5%D1%82) и других мобильных и энергоэффективных устройствах;

- персональные компьютеры (на основе процессоров Pentium, многоядерных процессоров Core Duo, Core i3, i5 и i7) – ВМ, предназначенные для работы одного пользователя;

- рабочие станции (Sun Work Stations) – ВМ большей производительности, чем ПК; имеют проблемную ориентацию или управляют несколькими ПК, объединенными в простую (локальную) сеть;

- средние и большие машины (Host computers) – вычислительные системы из нескольких процессоров (CDC6600, HP9000, Series800, SGI); это системы, которые предназначены для решения сложных задач обработки данных или управления большим числом ПК, объединенных в глобальную сеть;

- суперкомпьютеры – системы с параллельной архитектурой векторно-матричного типа ( Illiac IV, VP-2000, Эльбрус ), имеющие сверхвысокую производительность обработки данных.

# *1.3. Принцип программного управления и машина фон Неймана*

Фон Нейман впервые предложил в 40-х годах XX века концепцию хранимой программы, основные принципы которой заключаются в следующем:

1. ***Двоичное кодирование:*** вся информация (как команды, так и данные) кодируется двоичными цифрами 0 и 1, поскольку двоичное кодирование по теории информации близко к оптимальному, а кроме того, легче реализовать элементы с двумя устойчивыми состояниями (магнитные сердечники, триггеры).
2. ***Программное управление***: команды программы, так же как и данные, хранятся в памяти машины; хранимая программа позволяет выполнять команды в естественном порядке следования либо осуществлять произвольный переход от одной команды к другой.
3. ***Однородность памяти:*** Вид хранимой информации (команды или данные непосредственно в памяти) неразличим, а зависит от последующего использования; команды могут обрабатываться так же, как и числовые данные (модификация команд – сейчас не поощряется), либо порождать в процессе обработки другие команды (трансляция – широко применяется).
4. ***Адресность:*** в команде указываются не сами данные, а адреса их размещения в памяти.

Основные особенности первых машин, построенных по изложенным принципам и называемых сейчас машинами фон неймановского типа, состоят в следующем:

1. наличие единого вычислительного устройства, включающего один процессор, память и некоторые внешние устройства;
2. использование линейной структуры адресации памяти со словами фиксированной длины;
3. централизованный принцип управления выполнением программы по последовательному алгоритму;
4. низкий уровень машинных команд, позволяющих выполнять только элементарные операции.

Для таких машин «узким» местом», ограничивающим производительность, является память и каналы связи: как данные, так и команды должны последовательно выбираться из памяти и передаваться между устройствами. Для повышения производительности в фон неймановских машинах применяются:

- увеличение разрядности обработки данных (16 бит🡪32 и 64 бит);

- активное использование конвейеризации при выборке и обработке команд;

- активное использование кэш-памяти (Cache – тайник, скрытый), т.е. модулей памяти, которые являются буферными между процессором и оперативной памятью.

Кроме того, наряду с *Принстонской архитектурой*, подразумевающей хранение команд и данных в общей памяти, распространяется *Гарвардская архитектура*, использующая раздельное хранение команд и данных.

# *1.4. Понятия архитектуры, организации и реализации компьютера*

Архитектура – это множество ресурсов ВМ, доступных пользователю на логическом уровне, без детализации способов взаимодействия процессоров, устройств памяти, внешних устройств и программных средств. При изучении архитектуры рассматривают:

- состав и характеристики процессоров, включая системы команд;

- состав и характеристики устройств памяти и ВУ;

- состав программных средств разработки ПО;

- вид ОС и режимы обработки данных.

Организация – это способы распределения функций, установления связи и взаимодействия процессоров, устройств памяти и внешних устройств, используемые для реализации возможностей, заложенных в архитектуре. При изучении организации рассматривают:

- представление и форматы данных;

- уровни памяти и их взаимодействие;

- состав и форматы машинных команд;

- систему прерываний;

- способы обмена данными.

Реализация – способы технического исполнения конкретных устройств, линий или шин связи и протоколов взаимодействия между ними.

Обычно на уровнях организации и реализации происходит перераспределение функций между аппаратными и программными средствами. Это порождает семейство машин одной архитектуры, но разной производительности и стоимости.

# *1.5. Многоуровневая организация компьютера*

В общем случае обработку информации на ВМ можно рассматривать в виде иерархической системы уровней, представленных в табл. 1.1.

Таблица 1.1

|  |  |  |
| --- | --- | --- |
| Пользователь данного уровня | Уровень | Примечания |
| Постановщик задач | **6 – концептуальный**  (язык спецификаций) | Задаются режимы и виды обработки данных, необходимые для решения задачи, состав системных ПС |
| Пользователь функционального ПО, решающий задачи из конкретной предметной области | **5 – проблемно-ориентированных ПС**  (входной язык пакета программ) | Уровень приложений для конкретной предметной области |
| Разработчик функциональных программных комплексов | **4 – промежуточного ПО**  (например, язык UML) | Middleware ( 1 - Delphi, Visual C;  2 - DCOM, CORBA, RMI) |
| Разработчик функциональных (прикладных) программ | **3 – языков высокого уровня** | Паскаль, СИ, С++, Java, Prolog |
| Системный программист,  прикладной программист | **2 – ассемблера** | Программирование фрагментов программ высокой эффективности |
| Системный программист | **1 – ОС** | Выполнения привилегированных команд, управление памятью |
| Программист/электронщик  (системный архитектор) | **0 – машинных команд** | Цифровое кодирование и представление команд |
| Программист/электронщик  (системный архитектор) | **(–1) – микрокоманд**  (микроархитектурный уровень) | Описание набора элементарных операций, реализующих машинные команды |
| Электронщик | **(–2) – межрегистровых передач** | Реализация элементарных операций как пересылок между регистрами |
| Электронщик  (технолог) | **(–3) – вентилей**  (цифровой логический уровень) | Технологический уровень, устройства машины представляются в виде интегральных схем |

*Системы промежуточного ПО*:

1. Инструментальные среды программирования (Delphi, Visual C, С++ Builder)

2. Инструментальные технологии программирования (DCOM, CORBA, RMI, ECLIPSE)

*Особенности многоуровневой организации*:

1. Каждый верхний уровень интерпретируется одним или несколькими нижними уровнями.

2. Каждый из уровней можно проектировать независимо.

3. Модификация нижних уровней не влияет на реализацию верхних.

4. Чем ниже уровень реализации программы, тем более высокая производительность достижима.

# *1.6. Понятие семантического разрыва между уровнями*

Преобразование операторов языков высокого уровня (ЯВУ) в машинный код или даже в микрокоманды требует от транслятора, во-первых, умения распознать операторы и команды различных уровней и, во-вторых, для любого оператора ЯВУ – генерировать десятки или сотни команд низкого уровня. Это приводит к усложнению транслятора, увеличению трудоемкости его разработки и снижению производительности генерируемых программ (особенно, при отсутствии оптимизации). Наличие этих проблем называют семантическим разрывом между уровнями. Способы его преодоления зависят от типа архитектуры ВМ:

1) для традиционных ВМ, считающихся машинами со сложным набором команд (CISC), используется специализация машин, при которой операторы проблемно-ориентированных языков могут непосредственно выполняться аппаратными средствами машины; платой за повышение производительности является увеличение сложности устройства управления и отход от универсальности; примерами могут служить: аппаратная реализация графических преобразований; аппаратная реализация операций с векторами и матрицами;

2) переход к ВМ с сокращенным набором команд (RISC), характеризующихся ограниченным списком простых команд, оперирующих в основном данными, размещенными в регистрах; в результате реализация операторов ЯВУ на основе команд RISC-процессора оказывается почти столь же эффективной, что и аппаратная реализация, но не усложняет устройства управления.

# *1.7. Организация аппаратных средств ВМ*

В зависимости от способов связи между устройствами различают следующие виды организации ВМ:

1. Структура **ВМ с непосредственными связями** показана на рис. 1.2.

ВУ1

ЦП ОП

ВУn

ЦП – центральный процессор

ОП – оперативная память

ВУ – внешнее устройство

Рис. 1.2

Каждое устройство может связываться с любым другим. Причем взаимодействие пары устройств можно организовать наиболее эффективно. Этот способ применялся в двух первых поколениях машин, но с возрастанием числа устройств машины такая организация становится сложной и дорогой в реализации.

2. Структура **ВМ с канальной организацией** показана на рис. 1.3.

ВУ

ВУ

Контроллер

Канал 1 (Мультиплексный)

ЦП ОП Канал 2 (Селекторный) Контроллер ВУ

Канал 3 (Мультиплексный)

Контроллер Контроллер

ВУ ВУ

ВУ ВУ

Рис. 1.3

Центральным элементом машины является память ОП, которая хранит программы ЦП и каждого из каналов, являющихся процессорами ввода-вывода, работающими параллельно с ЦП по собственной программе, выбираемой из ОП. Различают каналы: селекторный – управляет только одним ВУ и применяется для подключения быстрых устройств; мультиплексный – управляет несколькими более медленными ВУ.

При данной организации все еще очень большое количество связей. Большая специализация процессоров различного типа затрудняет их интегральное исполнение. Такая организация применялась в машинах третьего и частично четвертого поколений.

3.  Cтруктура **ВМ с магистральной организацией по типу «общая шина (Unibus)»** показана на рис. 1.4**.**

А

Р

Б Общая шина (ОШ)

ЦП И

Т

Р

Память К1 МЛТП

ВУ1 К1 К2 К3

ВУ ВУ ВУ

Рис.1.4

Магистрально-модульная организация компьютера предполагает выделение общего универсального канала (магистрали связи между элементами системы – модулями) и определения общих правил взаимодействия. В центре ВМ – центральный процессор, управляющий информационной связью между устройствами, подключенными к магистрали (ВУ и память). ***Магистраль,*** называемая также ***Общей шиной*** (ОШ), представляет собой множество проводов. По одной группе проводов (шина данных) передается обрабатываемая информация, по другой (шина адреса) – адреса памяти или ВУ, к которым обращается процессор. Есть еще третья часть магистрали – шина управления, по ней передаются управляющие сигналы (например, сигнал запуска операции в устройстве и др.). Всякая информация, передаваемая от процессора к другим устройствам по шине данных, сопровождается адресом, передаваемым по адресной шине. Это может быть адрес ячейки в оперативной памяти или адрес ВУ.

На схеме через МЛТП обозначен мультиплексор, обеспечивающий подключение нескольких ВУ к одному входу ОШ по нагрузочной способности, К1-К3 – контроллеры ВУ, Арбитр – аппаратная система приоритетов, разрешающая конфликты при одновременном обращении устройств к общей шине.

Типичная шинная транзакция включает в себя две части: посылку адреса и прием (или посылку) данных. Шинные транзакции обычно определяются характером взаимодействия с памятью: транзакция типа "Чтение" передает данные из памяти (либо в ЦП, либо в устройство ввода-вывода), транзакция типа "Запись" записывает данные в память.

В транзакции типа "Чтение" по шине сначала посылается в память адрес вместе с соответствующими сигналами управления, иницирующими чтение. Память отвечает, возвращая на шину данные с соответствующими сигналами управления. Транзакция типа "Запись" требует, чтобы ЦП или ВУ послало в память адрес и данные и не ожидает возврата данных. Обычно ЦП вынужден простаивать во время интервала между посылкой адреса и получением данных при выполнении чтения, но часто он не ожидает завершения операции при записи данных в память.

Используется единое адресное пространство ячеек памяти и внешних устройств; следовательно, все команды обработки данных процессора могут быть применены и к внешним устройствам. Общая шина является «узким местом» и снижает производительность и надежность машины.

4. Структура **ВМ с шинной организацией** показана на рис. 1.5.

Данная организация ВМ предложена для разгрузки шины, связывающей процессор с памятью, и как следствие – повышения производительности и надежности работы ВМ.

ВУ ВУ

ВУ ВУ

Контроллер 1 Контроллер N

Шина памяти

Память ЦП

Шина ввода / вывода

Шина прямого доступа к памяти (ПДП)

Контроллер ПДП ВУ

ВУ

Рис.1.5

При такой организации используются различные магистрали для связи ЦП с памятью и с внешними устройствами. Соответственно, используются различные адресные пространства для обращения к памяти и ВУ. Это требует выделения специальной группы команд ввода- вывода в системе команд процессора:

ADD AX, 100 ; адресуется ячейка памяти 100

IN AX, 100 ; адресуется внешнее устройство с номером 100

Шина прямого доступа к памяти (ПДП) используется для связи ВУ и памяти без участия процессора.

# Представление и обработка данных в ВМ

В качестве используемых и обрабатываемых в ВМ типов данных следует указать:

1. целые и вещественные числа, участвующие в арифметической обработке;
2. коды команд и адреса памяти (беззнаковые целые числа);
3. коды символов (беззнаковые целые числа), используемые в текстовых сообщениях;
4. битовые наборы (последовательность нулей и единиц), используемые в логических операциях;
5. отдельные биты, используемые в операциях условных переходов и как биты состояния устройств ВМ;
6. данные мультимедиа обработки (видео и аудио информация).

## Целые числа

Представляются в позиционной системе счисления в виде

![](data:image/x-wmf;base64,183GmgAAAAAAAAAiQAQACQAAAABReAEACQAAA4cEAAACADwBAAAAAAUAAAACAQEAAAAFAAAAAQL///8ABQAAAC4BGQAAAAUAAAALAgAAAAAFAAAADAJABAAiEwAAACYGDwAcAP////8AAE4AEAAAAMD///+v////wCEAAO8DAAALAAAAJgYPAAwATWF0aFR5cGUAAOAABQAAAAkCAAAAAgUAAAAUAtQBLA4cAAAA+wIi/wAAAAAAAJABAAAAAAACABBUaW1lcyBOZXcgUm9tYW4A6LHzd/Gx83cgQPV3nxFmlQQAAAAtAQAADQAAADIKAAAAAAQAAAAxMjEwSQZdBocGvAEFAAAAFALjAtwLHAAAAPsCIv8AAAAAAACQAQAAAAAAAgAQVGltZXMgTmV3IFJvbWFuAOix83fxsfN3IED1d58RZpUEAAAALQEBAAQAAADwAQAADQAAADIKAAAAAAQAAAAxMjEwIAaKB2EGvAEFAAAAFALsA/IDHAAAAPsCIv8AAAAAAACQAQAAAAAAAgAQVGltZXMgTmV3IFJvbWFuAOix83fxsfN3IED1d58RZpUEAAAALQEAAAQAAADwAQEACQAAADIKAAAAAAEAAAAwebwBBQAAABQCgAI9BhwAAAD7AoD+AAAAAAAAkAEAAAAAAAIAEFRpbWVzIE5ldyBSb21hbgDosfN38bHzdyBA9XefEWaVBAAAAC0BAQAEAAAA8AEAABIAAAAyCgAAAAAHAAAAKi4uLi4uLgYQEGAAYACMBWAAYAAAAwUAAAAUAvoANQMcAAAA+wIi/wAAAAAAAJABAQAAAAACABBUaW1lcyBOZXcgUm9tYW4A6LHzd/Gx83cgQPV3nxFmlQQAAAAtAQAABAAAAPABAQAMAAAAMgoAAAAAAwAAAG4tMRFvAEgAvAEFAAAAFALUARMIHAAAAPsCIv8AAAAAAACQAQEAAAAAAgAQVGltZXMgTmV3IFJvbWFuAOix83fxsfN3IED1d58RZpUEAAAALQEBAAQAAADwAQAADAAAADIKAAAAAAMAAABpbm5CLQUxBrwBBQAAABQC4wKpBRwAAAD7AiL/AAAAAAAAkAEBAAAAAAIAEFRpbWVzIE5ldyBSb21hbgDosfN38bHzdyBA9XefEWaVBAAAAC0BAAAEAAAA8AEBAAwAAAAyCgAAAAADAAAAaW5uEkcFCAa8AQUAAAAUAuwDHwMcAAAA+wIi/wAAAAAAAJABAQAAAAACABBUaW1lcyBOZXcgUm9tYW4A6LHzd/Gx83cgQPV3nxFmlQQAAAAtAQEABAAAAPABAAAJAAAAMgoAAAAAAQAAAGl5vAEFAAAAFAKAAkwAHAAAAPsCgP4AAAAAAACQAQEAAAAAAgAQVGltZXMgTmV3IFJvbWFuAOix83fxsfN3IED1d58RZpUEAAAALQEAAAQAAADwAQEAEAAAADIKAAAAAAYAAABOU1NTU1PhBiYFMQZ5B3IGAAMFAAAAFAKAAqUEHAAAAPsCgP4AAAAAAACQAQEAAAEAAgAQU3ltYm9sAAAhEQoUaNkSAOix83fxsfN3IED1d58RZpUEAAAALQEBAAQAAADwAQAADwAAADIKAAAAAAUAAABhYWFhYQBABQgGpghMBgADBQAAABQC1AG9DRwAAAD7AiL/AAAAAAAAkAEAAAABAAIAEFN5bWJvbAAAHREKRWjZEgDosfN38bHzdyBA9XefEWaVBAAAAC0BAAAEAAAA8AEBAAoAAAAyCgAAAAACAAAALS0xBrwBBQAAABQC4wJtCwoAAAAyCgAAAAACAAAALS0IBrwBBQAAABQC7ANuAwkAAAAyCgAAAAABAAAAPS28AQUAAAAUAoACzAEcAAAA+wKA/gAAAAAAAJABAAAAAQACABBTeW1ib2wAACERChVo2RIA6LHzd/Gx83cgQPV3nxFmlQQAAAAtAQEABAAAAPABAAASAAAAMgoAAAAABwAAAD09KysrKysGCwcaBloGTAIABEwCAAMFAAAAFALYAvUCHAAAAPsCwP0AAAAAAACQAQAAAAEAAgAQU3ltYm9sAAAdEQpGbNkSAOix83fxsfN3IED1d58RZpUEAAAALQEAAAQAAADwAQEACQAAADIKAAAAAAEAAADlLYAEPAEAACYGDwBtAk1hdGhUeXBlVVVhAgUBAAUCRFNNVDUAABNXaW5BbGxCYXNpY0NvZGVQYWdlcwARBVRpbWVzIE5ldyBSb21hbgARA1N5bWJvbAARBUNvdXJpZXIgTmV3ABEETVQgRXh0cmEAEgAIIS9Fj0QvQVD0EA9HX0FQ8h8eQVD0FQ9BAPRF9CX0j0JfQQD0EA9DX0EA9I9F9CpfSPSPQQD0EA9A9I9Bf0j0EA9BKl9EX0X0X0X0X0EPDAECAQABAgICAgACAAEBAQADAAEABAAACgEAAgCDTgACBIY9AD0DABBwAAEAAgSEsQNhAwAbAAALAQACAINpAAABAQAAAQACAIFpAAIEhj0APQIAiDAAAAEAAgCBbgACAIEtAAIAgTEAAA0CBIYRIuUACgIAgioAAgCDUwADABwAAAsBAQEAAgCDaQAAAAoCBIY9AD0CBISxA2EDABsAAAsBAAIAg24AAgSGEiItAgCIMQAAAQEACgIAg1MAAwAcAAALAQEBAAIAg24AAgSGEiItAgCIMQAAAAoCBIYrACsCBISxA2EDABsAAAsBAAIAg24AAgSGEiItAgCIMgAAAQEACgIAg1MAAwAcAAALAQEBAAIAg24AAgSGEiItAgCIMgAAAAoCBIYrACsCAIIuAAIAgi4AAgCCLgACBIYrACsCBISxA2EDABsAAAsBAAIAiDEAAAEBAAoCAINTAAMAHAAACwEBAQACAIgxAAAACgIEhisAKwIAgi4AAgCCLgACAIIuAAIEhisAKwIEhLEDYQMAGwAACwEAAgCIMAAAAQEACgIAg1MAAwAcAAALAQEBAAIAiDAAAAAAAAALAAAAJgYPAAwA/////wEAAAAAAAAAHAAAAPsCEAAHAAAAAAC8AgAAAMwBAgIiU3lzdGVtAJWfEWaVAAAKACEAigEAAAAAAQAAALTjEgAEAAAALQEBAAQAAADwAQAAAwAAAAAA) ,

где S – основание системы счисления (СС), используются S = {2,8,10,16},

αi =[0, s-1] - разрядный коэффициент

Если аппаратные средства ВМ используют двоичную СС (S=2), то в программах для компактной записи чисел применяют S = 8, 10,16. При записи чисел в программах для указания СС применяют окончания: B (двоичный), O (восьмеричный), D или пусто (десятичный), H (шестнадцатиричный). Приведем примеры записи чисел и их десятичные значения: 101B = 5, 101O = 65, 101D = 101, 101H = 257.

Для представления 16-ричных цифр, больших 9, используют буквы:

10 – A , 11 – B, 12 – C, 13 – D, 14 – E, 15 – F .

Наконец, заметим, что смешанные числа, содержащие целую и дробную часть, в позиционной СС в форме с фиксированной точкой представляются в виде

![](data:image/x-wmf;base64,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)

***Для преобразования целых чисел (ЦЧ) из одной СС в другую*** используется правило: для получения числа в новой СС надо его значение в старой СС разделить на основание новой СС, представленное в старой СС, и последовательно получаемые числа остатка взять в обратном порядке. При этом для преобразования большого числа в двоичную СС лучше сначала преобразовать его в 16-ричную СС и затем каждую цифру заменить на тетраду (4 бита) ее двоичного изображения.

***Для преобразования дробной части смешанного числа из одной СС в другую*** используется правило:

для получения дробной части числа в новой СС надо его значение в старой СС умножить на основание новой СС, представленное в старой СС, целую часть частичного произведения зафиксировать, а дробную снова умножить на основание новой СС и так повторять пока дробная часть очередного произведения не станет равной 0 или не будет достигнута требуемая точность. Полученные цифры целых частей произведений записать в прямом порядке как дробную часть числа в новой СС.

***Обработка целых чисел****.*

Различают беззнаковое и знаковое (с учетом знака) представления и обработку ЦЧ. Беззнаковые двоичные ЦЧ длиной n бит изменяются в диапазоне [0, Nmax], где Nmax = 2n – 1 . Например:

n = 4 - диапазон [0, 15] , n = 8 - диапазон [0, 255] , n = 16 - диапазон [0, 65535],

n = 32 - диапазон [0, ≈ 232  = 4\*230 ≈ 4\* (103) 3 = 4 \*109].

Если результат арифметической обработки беззнаковых ЦЧ выходит за допустимый диапазон изменения, то возникает переполнение, которое фиксируется по наличию переноса из старшего разряда результата операции и установке флага переноса в «1».

При использовании ЦЧ с учетом знака диапазон их изменения разбивается на две части: положительные числа ( для n-битного числа - [0, 2n-1 – 1] ) и отрицательные числа [- 2n-1 , 0]. Если результат арифметической обработки положительного числа превышает 2n-1 – 1, то возникает переполнение (положительное), а для отрицательных чисел переполнение (отрицательное) возникает, если результат меньше (- 2n-1). ЦЧ с учетом знака могут представляться в 3-х формах: прямой код и два инверсных кода: обратный и дополнительный. Во всех 3-х формах старший разряд считается знаковым и для положительных чисел равен 0, а для отрицательных равен 1.

Положительные числа во всех 3-х формах представляются одинаково «0&информационные разряды числа», где &-конкатенация (присоединение). Так, для 4-х -битных ЦЧ с диапазоном изменения [-8,7] число 5 будет иметь двоичное представление 0101. Представления отрицательных чисел различны.

Прямой код (ПК) отрицательного ЦЧ имеет вид «1&информационные разряды числа». Соответственно, число [-5] в ПК будет иметь вид [-5]пк = 1101.

Замечание: В прямом коде существуют: положительный ноль, равный 0000 и отрицательный ноль, равный 1000.

Обратный код (ОК) отрицательного ЦЧ имеет вид «1&инверсные значения информационных разрядов числа». Соответственно, число [-5] в ОК будет иметь вид [-5]ок = 1010. В ОК существуют: положительный ноль, равный 0000 и отрицательный ноль, равный 1111.

При работе с 16-ричными числами следует учитывать, что инверсные значения 16-ричных цифр имеют вид:

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 16-ричная цифра | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| инверсная цифра | F | E | D | C | B | A | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Дополнительный код (ДК) отрицательного ЦЧ имеет вид «обратный код числа +1». Соответственно, число [-5] в ДК будет иметь вид [-5]дк = 1011. В ДК существует только один ноль, равный 0000.

В настоящее время при алгебраическом сложении целых чисел доминирует использование ДК по следующим причинам:

1. ДК имеет единственное изображение нуля: +0 и −0 имеют вид 0…000;
2. При возникновении переноса из старшего разряда результата алгебраического сложения ЦЧ в ДК перенос просто отбрасывается, а для ОК он должен циклически прибавляться к младшему разряду результата, что увеличивает время выполнения операции;
3. Для преобразования числа длиной n разрядов в число с большей разрядностью в ДК достаточно выполнить распространение знака в новые разряды:

+5 для n = 4 в ДК имеет вид 0101, а для n = 8 имеет вид 00000101;

-5 для n = 4 в ДК имеет вид 1011, а для n = 8 имеет вид 11111011.

При выполнении сложения ЦЧ переполнение возникает только тогда, когда операнды имеют одинаковые знаки, а знак результата противоположный.

При выполнении операций умножения и деления используется представление ЦЧ в прямом коде.

Знак результата формируется как «исключающее ИЛИ» или «сумма по mod2» знаков операндов. Умножение выполняется следующим образом An \* Bn = C2n . При этом переполнение не возникает. Деление выполняется следующим образом A2n / Bn = {C1n (n-битное частное)иC2n (n-битный остаток)}.Знак частного вычисляется как «сумма по mod2» знаков делимого и делителя, знак остатка равен знаку делимого. Переполнение фиксируется, если частное не размещается в n – разрядах при делении на 0 или если A > 2n \* B.

**П**ри решении экономических задач часто возникает потребность в обработке десятичных чисел. Для этого используется их двоично-десятичное представление, при котором каждый десятичный разряд числа представляется двоичной тетрадой (4 битами) цифр с весами 8421. Значения тетрады 1010 ÷ 1111, соответсвующие 16-ричным цифрам A ÷ F, считаются запрещенными и их получение при сложении данных требует коррекции результата. Коррекция выполняется путем прибавления к результату так называемого «десятичного заполнителя» 610 = 01102 . Например, при сложении десятичных чисел 8 + 5 =13, представленных в двоично-десятичном формате имеем

1000 + 0101 = 1101 (запрещенный код) +0110 = 0001 0011 = 1310

Для выполнения такой коррекции в ВМ с архитектурой Intel X86 предусмотрены специальные команды типа DAA, исполняемые после обычной команды сложения ADD. Аналогичные корректирующие операции и команды предусмотрены для выполнения вычитания.

## Представление и обработка вещественных чисел.

Вещественные числа (ВЧ) в компьютерах обычно представляются в форме с плавающей точкой в виде

N = m \* S P , где S – основание СС, m – мантисса, P – порядок.

Такая форма позволяет, задавая различные значения m и P, получить разные представления одного и того же числа

N = 5.41 \*100 = 0.541\*101 = 541\*10-2 = 0.00541\*103

Для повышения точности ВЧ обычно используют их **нормализованное** представление, при котором на мантиссу накладывается ограничение 1/S ≤ m < 1 (представление N = 0.541\*101  - нормализованное) .

Основные форматы представления ВЧ имеют следующие распределения двоичных разрядов (1 – 8 – 23) - короткий формат и (1 – 11–52) – длинный формат. Короткий формат поясняется ниже рисунком.

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| 0 | | 1 2 8 | | 9 31 |
| Sm | | Sp | P | m |
|  | порядок | | | Мантисса |

Здесь Sm – знак мантиссы или знак числа, Sp – знак порядка.

При использовании короткого формата имеем диапазон изменения ВЧ [ - Nmax, Nmax] , где

Nmax = 1\* 2Pmax = 2128 = ( 210 )12.8  ≈ ( 103 )12.8 ≈ 1038

При этом ошибка представления ВЧ, определяемая весом младшего разряда мантиссы, будет равна

δ = 2 -23 = ( 210 ) -2.3  ≈ ( 103 ) -2.3 ≈ 10 -7 ,

то есть обеспечивается точность на уровне 7 десятичных разрядов.

Для длинного формата ВЧ соответственно получим диапазон [- 10308 , 10308 ] и точность - 17 десятичных разрядов.

В целом следует отметить, что форма представления ВЧ с плавающей точкой позволяет значительно увеличить диапазон обрабатываемых ВЧ за счет некоторой потери точности из-за того, что часть разрядов числа отводится под порядок.

Короткий формат при невысокой точности значений позволяет размещать в памяти большее число операндов и выполнять операции с небольшими затратами времени, а длинный формат обеспечивает возможность вычислений с повышенной точностью.

Выполнение операций алгебраического сложения над ВЧ состоит из трех этапов:

1. Выравнивание порядков операндов – выпоняется в сторону большего порядка: увеличение на 1 меньшего порядка сопровождается сдвигом на 1 раздряд вправо мантиссы числа с меньшим порядком; этот процесс продолжается пока порядки операндов не станут равны.
2. Суммирование мантисс – выполняется по правилам сложения целых чисел.
3. Нормализация результата.

При суммировании мантисс может произойти выход суммы за диапазон разрядной сетки, но это не переполнение, а нарушение нормализации влево. Оно происходит только на 1 разряд и исправляется сдвигом мантиссы на 1 разряд вправо и увеличением порядка на 1. Переполнение возникает только в случае, если перед этим Р = Рmax .

Нарушение нормализации вправо возникает при сложении близких по абсолютной величине чисел с разными знаками. При этом часть старших разрядов суммы принимает значения 0 (для положительной суммы) или 1 (для отрицательной суммы в ДК). Исправляется последовательным сдвигом мантиссы суммы на нужное число разрядов влево, сопровождающееся вычитанием 1 из порядка. Если при этом потребуется вычесть 1 из Р = ‒ Рmax , то возникает отрицательное переполнение, называемое «потерей значимости» и результат приравнивается к нулю.

При выполнении операций умножение или деление порядки операндов участвуют в алгебраическом сложении как целые числа (суммируются при умножении или вычитаются при делении), а мантиссы перемножаются или делятся также как целые числа. Считаем, что исходные операнды представлены в нормализованной форме. Тогда при умножении может возникнуть нарушение номализации вправо на 1 разряд, которое исправляется сдвигом мантиссы результата на 1 разряд влево и вычитанием 1 из порядка. Также при умножении может возикнуть переполнение, если Р1 + Р2 > Рmax или потеря значимости, если Р1 + Р2 < ‒ Рmax . При делении может возникнуть переполнение при нулевой мантиссе делителя или, если Р1 - Р2 > Рmax , а также потеря значимости при исправлении нарушения номализации влево или, если Р1 - Р2 < ‒ Рmax .

## Логические операции над битовыми наборами

Логические операции над битовыми наборами выполняются поразрядно в соответствии с таблицей 2.1.

Таблица 2.1

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| X | Y | X AND Y | X OR Y | X XOR Y | NOT X | NOT Y |
| **0** | **0** | **0** | **0** | **0** | **1** | **1** |
| **0** | **1** | **0** | **1** | **1** | **1** | **0** |
| **1** | **0** | **0** | **1** | **1** | **0** | **1** |
| **1** | **1** | **1** | **1** | **0** | **0** | **0** |

В случае многоразрядных битовых наборов операнды удобно представлять в компактной форме как целые числа в 16-ричной СС, учитывая, что одна цифра представляет тетраду (4 бита), и в таком же виде выполнять логические операции.

## Представление и обработка символов.

Представление символьной информации основано на сопоставлении каждому символу определенной числовой (обычно двоичной) комбинации. Совокупность символов и назначенных им числовых кодов образует ***таблицу кодировки.*** В настоящее время известно много таблиц кодировки, но их объединяет весовой принцип, также называемый принцип лексикографического упорядочения кодов символов. Суть его состоит в том, что коды цифр возрастают по мере увеличения цифры, а коды буквенных символов увеличиваются в алфавитном порядке. Так, код буквы «Б» на 1 больше кода буквы «А». Это упрощает обработку символьной информации, в частности, облегчает сортировку, упорядочивание и поиск символьных данных.

Наиболее известной таблицей кодировки является ASCII – код (American Standard Code for Information Interchange), использующий для кодирования символа 7 информационных бит + 1 бит контроля четности. Он позволяет представить 128 символов, включающих латинские буквы, знаки пунктуации и знаки математических операций. Его отечественный аналог называется КОИ-7. Позже появилась его европейская модификация Latin 1 (стандарт ISO 8859), использующий для кодирования все 8 бит и позволяющий представить буквы европейских языков, а также математических и финансовых символов. В зависимости от набора символов различают разные версии стандарта: ISO 8859-1 (западно-европейские языки), ISO 8859-2 (языки стран центральной и восточной Европы), ISO 8859-5 (языки славянских стран с кириллицей) и т.д. В операционной системе MS-DOS стандарт ISO 8859 реализован в виде кодовых страниц (Code Page), каждая из которых имеет свой идентификатор. Так, кодовая страница России имеет идентификатор CP866.

Недостаточное количество кодовых комбинаций в стадарте ISO 8859 привело к тому, что в 1993 году ряд ведущих IT – компаний (IBM, Microsoft, Apple, DEC, Hewlett-Packard) разработали 16-битовый стандарт ISO 10646, названный UCS (Universal Character Set) или Unicode, который позволяет кодировать до 65536 символов. Для букв русского языка выделены коды 1040 ÷ 1093.

Следует заметить, что при вводе символов путем нажатия клавиш на клавиатуре ВМ для повышения надежности получения кода символа используются, так называемые скан-коды, различающие код нажатой и отпущенной клавиши, например, по старшему биту однобайтного кода символа: 1 – клавиша нажата, 0 – отпущена. Для современных клавиатур существуют различные системы скан-кодов и способов сообщения об отпускании клавиши.

## Представление видеоинформации и аудиоинформации.

Рассмотренные ранее виды информации имели чисто статический характер. В современных ВМ также используются виды информации динамического или смешанного типа.

* + 1. **Видеоинформация.**

Видеоинформация (ВИ) бывает статической и динамической. К статической ВИ относятся рисунки, графики, чертежи, таблицы и т.п. К динамической ВИ - видео- и слайд-фильмы. Динамическая ВИ исполь- зуется либо для передачи движущихся изображений (анимация), либо для последовательной демонстрации отдельных кадров.

При этом существует два способа представления графических изображений: матричный (растровый) и векторный. В матричных форматах изображение представляется матрицей точек - *пикселов* (picture element), положение которых в матрице соответствует координатам точек на экране. Каждый пиксел характеризуется большим количеством атрибутов, определяющих цвет, фон, яркость и другие свойства и может занимать до 30 бит. Учитывая, что количество пикселов на экране может быть более миллиона, основным недостатком матричной графики является требование большого объема памяти для хранения изображений и необходимость сжатия данных. К распространенным матричным форматам относятся BMP, GIF, JPEG,PNG.

Векторное представление описывает изображение не пикселами, а кривыми – сплайнами. Сплайн – гладкая кривая, проходящая через несколько (2-4) опорных точек, задающих форму сплайна. В векторной графике распространены сплайны на основе кривых Безье. Любую элементарную кривую можно построить, зная четыре коэффициента Р0, Р1, Р2, Р3, соответствующих четырем точкам на плоскости. Перемещение точек влечет изменение формы кривой. Для многих видов изображений их описание с помощью математических формул является более простым способом благодаря легкости масштабирования и существенно меньшим требованиям к памяти. Недостатком векторных изображений является необходимость разбиения изображений на множество составляющих его примитивов (линия, прямоугольник, эллипс) и более низкое качество. К распространенным векторным форматам относятся CDR, DXF, PS, SVG, VSD.

* + 1. **Аудиоинформация**

Аудиоинформация имеет чисто динамический характер и связана с представлением звуковых сигналов, частоты которых лежат в диапазоне 15 Гц ÷ 20 КГц, являющихся по своей природе непрерывными (аналоговыми). Поэтому для использования в ВМ аудиоинформация должна быть представлена в виде значений (выборок), взятых через определенные интервалы времени, и преобразована в цифровую форму с помощью аналого-цифрового преобразователя (АЦП). После обработки в ВМ для воспроизведения звуковые сигналы должны быть восстановлены в аналоговую форму с помощью цифро-аналогового преобразователя (ЦАП). Для обеспечения высокого качества воспроизведения требуется большое количество выборок и соответственно большая емкость памяти для хранения аудиоинформации. Это приводит к необходимости использования различных методов сжатия данных для сокращения требуемого объема памяти. К распространенным форматам представления аудиоинформации следует отнести AVI, WAV, AIF, MPEG.

# Организация процессора и основной памяти ВМ

В разделе идет речь о машинах с контроллерным управлением, в которых порядок выполнения команд явно задается программой. Машины с потоковым управлением и машины с запросным управлением (редукционные) в данном курсе не рассматриваются.

**Процессор** выполняет две функции:

- обработка данных в соответствии с заданной программой;

- управление всеми устройствами машины.

Управление в соответствии с заданной программой представляется в виде последовательности команд, представленных в цифровой форме (кодированных). Структура каждой команды состоит из двух частей: операционной и адресной. Операционная часть задает код операции и режим ее выполнения. Адресная часть содержит сведения о размещении операндов (входные данные и результат операции) в виде:

- непосредственно самих значений данных;

- адресов расположения данных в памяти;

- сведений для определения адресов размещения данных в памяти.

Формирование исполнительного адреса – этап перехода от сведений об адресе к самому адресу. В адресной части могут быть сведения об отсутствии операндов (нуль-адресная или безадресная команда ) и адресации от одного (одноадресная команда) до трех операндов (трехадресная команда).

# *3.1. Типовая структура процессора и основной памяти*

Типовая структура центральной части ВМ – процессора и основной памяти представлена на рис. 3.1.

А

Д

У

Операционная часть {Θj} Управляющая часть {Θi} Память

АЛУ Внутренние Рг РАП

{У j } {Уi}

РОНы Рг СС РДП

ПСч Накопитель

Рг команд Контроллер памяти

Рг УиС

ДешКОПиРА

ФормировательУС

ЦП ГТ

Рис. 3.1

На схеме, показанной на рис. 3.1, использованы следующие компоненты процессора и памяти:

* АЛУ – арифметико-логическое устройство выполняет операции по обработке данных;
* РОНы – регистры общего назначения (от 8 до нескольких сотен штук) – сверхбыстрая память малой емкости для хранения операндов;
* Рг СС – регистр слова состояния. Содержит текущее состояние процессора, в который входит уровень приоритета текущей программы, биты условий {Θj}завершения последней команды, режим обработки текущей команды. Возможны следующие режимы обработки (в порядке возрастания уровня приоритета):

- User Mode – режим пользователя; в этом режиме не могут выполнятся системные команды (команды изменения состояния процессора и команды ввода-вывода);

- SuperVisor Mode – режим супервизора; обеспечивается выполнение всех команд ввода- вывода;

- Kernel Mode – режим ядра; в нем возможно выполнение всех команд процессора;

* ПСч – программный счетчик. Содержит адрес текущей команды и автоматически наращивается для подготовки адреса следующей команды (исключение составляет команда перехода);
* Рг Команд – регистр команд. Содержит код исполняемой в данный момент команды;
* ДешКОПиРА – дешифратор кода операции и режимов адресации;
* Формирователь УС – формирователь управляющих сигналов { Уi };
* РАП - регистр адреса памяти; РДП - регистр данных памяти;
* Рг УиС – регистр управления и состояния контроллера памяти.

# *3.2. Основной цикл работы процессора*

В основной цикл, реализуемый процессором при выполнении любой команды, входят следующие этапы:

1. Выборка команды (Instruction Fetch).
2. Декодирование команды (Instruction Decoding).
3. Выборка операндов из памяти (Operand Fetch).
4. Исполнение операции (Execution).
5. Сохранение результата (Store).

Большинство этапов для выполнения требуют как минимум один цикл памяти.

Для ускорения выборки и обработки команд программы используется конвейерный способ выполнения этих этапов (при выполнении очередного этапа текущей команды одновременно происходит выполнение предыдущего этапа следующей команды), схематично показанный на рис. 3.2. Разумеется, если одна команда изменяет содержимое какой-либо ячейки памяти, а следующая использует ее новое значение, то последняя не может начать исполняться, пока результат не будет сохранен.

Б1 Б2 Б3 Б4 Б5

Сохранение результата

Исполнение операции

Выборка операндов

Декодирование команды

Выборка команды

|  |  |
| --- | --- |
| Б1 | 7  6  5  4  3  2  1 |
| Б2 | 6  5  4  3  2  1 |
| Б3 | 5  4  3  2  1 |
| Б4 | 4  3  2  1 |
| Б5 | 3  2  1 |

Время

Рис.3.2.

После выполнения основного цикла процессора, как правило, происходит проверка запроса программного прерывания. Вообще, в процессе выполнения команд программы возможно появление запросов прерываний двух видов:

* запрос программного прерывания, который обслуживается процессором путем выполнения специальной программы – обработчика прерываний, требует сохранения текущего состояния управляющих и операционных узлов процессора и поэтому проверяется и обслуживается только после завершения выполнения очередной команды;
* запрос аппаратного прерывания, обслуживается специальными аппаратными средствами без участия программы процессора и не требует сохранения его состояния, поэтому может поступать и обслуживаться после завершения любого этапа цикла процессора, прерывая выполнение текущей команды.

Подробнее о прерываниях будет сказано позже в разделе 7.

# *3.3. Организация процессора и памяти в архитекуре Intel X86.*

В процессоре Intel 8086 длина слова составляет 16 бит или 2 байта. Минимально адресуемой и обрабатываемой единицей информации является байт, при этом адрес слова совпадает с адресом младшего байта и является четным. При разрядности адреса 16 бит максимальная емкость прямо адресуемой памяти составляет   
216 = 64 Кбайт. Для расширения адресуемого пространства памяти используется ее разбиение на блоки – сегменты, называемое сегментированием памяти. Каждый сегмент имеет произвольную длину, не превышающую  
64 Кбайт. Адрес байта в сегментированной памяти задается двумя составляющими: сегментная часть (16 бит), определяющая адрес начала сегмента, и смещение (16 бит) байта в пределах сегмента. Обычно адрес представляется в виде пары Сегмент (Segment) : Смещение (Offset). Начало размещения сегмента выравнивается на границу блока памяти из 16 байт, называемого «параграфом». Соответственно, физический адрес памяти получается путем суммирования сегмента, сдвинутого на 4 бита влево, со значением смещения. Результатом такого суммирования является 20-битный физический адрес, чем обеспечивается адресация 1 Мбайт памяти.

***Пример.*** Пусть Segment = DCBA, Offset = 5678.

Физический адрес Adr будет определяться суммой: DCBA0 + 5678 = E2218.

# 3.3.1. Программно доступные регистры процессора

Начиная с 80386, процессоры Intel предоставляют 16 основных регист­ров для пользовательских программ плюс еще 11 регистров для работы с числами с плавающей запятой (FPU/NPX) и мультимедийными при­ложениями (ММХ). Все команды так или иначе изменяют значения ре­гистров, и всегда быстрее и удобнее обращаться к регистру, чем к памяти.

*Регистры общего назначения*

16-битные регистры АХ (аккумулятор), ВХ (база), СХ (счетчик), DX (регистр данных) могут использоваться без ограничений для любых це­лей – временного хранения данных, аргументов или результатов различ­ных операций. На самом деле, начиная с процессора 80386, все эти регистры имеют размер 32 бита и называ­ются они ЕАХ, EВХ, EСХ, EDX. Кроме этого, отдельные байты в 16-бит­ных регистрах АХ - DX тоже имеют свои имена и могут использоваться как 8-битные регистры. Старшие байты этих регистров называются АН, ВН, СН, DH, а младшие - AL, DL, CL, DL.

Другие четыре регистра общего назначения (РОН) – SI (индекс источни­ка), DI (индекс приемника), BP (указатель базы), SP (указатель сте­ка) – имеют более конкретное назначение и могут применяться для хра­нения всевозможных временных переменных, только когда они не используются по назначению. Регистры SI и DI используются в стро­ковых операциях, ВР и SP используются при работе со стеком. Так же как и для регистров АХ - DX, начиная с процессора 80386, эти четыре регистра являются 32-битными, называются ESI, EDI, EВР и ESP соответственно и могут использоваться как универсальные РОН.

*Сегментные регистры*

При использовании памяти для формирования любого адреса применяются два числа – адрес начала сегмента и смещение искомого байта относительно этого начала. Для хранения адреса начала сегмента в процессорах Intel8086 предусмотрены следующие сегментные регистры – CS (сегмент кода), DS (сегмент данных), ES (дополнительный сегмент данных), SS(сегмент стека). Начиная с процессора 80386, появились дополнительные регистры FS и GS.

Смещение следующей выполняемой команды всегда хранится в специальном регистре – IP (указатель инструкции), принудительная запись в кото­рый приведет к тому, что следующей будет исполнена какая-ни­будь другая команда, а не команда, расположенная сразу за данной. В общем случае при передаче управления в другой сегмент команды безусловного перехода, вызова подпрограммы и т. п. – осуществляют запись в регистры CS и IP.

*Регистр флагов*

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Х | Х | Х | Х | OF | DF | IF | TF | SF | ZF | 0 | AF | 0 | PF | 1 | CF |

0

7

8

15

CF - флаг переноса (CARRY);

PF - флаг четности (PARITY);

AF - дополнительный флаг переноса (AUXILARY);

ZF - флаг нуля (ZERO);

SF - знаковый флаг (SIGN);

TF - флаг слежения, ловушка (TRAP);

IF - флаг прерываний (INTERRUPTION);

DF - флаг направления (DIRECTION);

OF - флаг переполнения (OVERFLOW).

# 3.3.2. Организация стека в архитектуре Intel Х86

Стек – специальная область памяти, достуная для записи (заполнения) и выборки (выталкивания) данных только с одного конца, называемого верхушкой стека. В процессорах Intel Х86 на верхушку стека указывает РОН указатель стека (SP – stack pointer), стек может работать только со словами, заполнение стека происходит в сторону уменьшения адресов с помощью команды PUSH, а освобождение стека (выталкивание данных из стека) – в сторону увеличения адресов командой РОР.

По существу команды PUSH AX и POP AX, соответственно сохраняющая содержимое РОН AX в стеке и восстанавливающая содержимое РОН AX из стека, выполняются в два приема:

PUSH AX: POP AX:

(SP)-2🡪SP [SP]🡪AX

(AX)🡪[SP] (SP)+2🡪SP

При выполнении программ в процессорах Intel Х86 стек используется в случаях:

* промежуточного хранения содержимого регистра или группы регистров;
* обмена содержимого регистров;
* сохранения адресов возврата при вызове подпрограмм;
* передачи параметров между вызываемой и вызывающей программами;
* сохранения адресов возврата и регистра флагов при обработке прерываний.

# 3.3.3. Организация выполняемых программ в MS DOS

Поскольку выполнение лабораторных работ по курсу происходит в среде ОС MS DOS, рассмотрим основные типы исполняемых файлов:

* \*.bat – задают порядок выполнения некоторой последовательности программ;
* \*.com – файлы исполняемых программ типа com;
* \*.exe – файлы исполняемых программ типа exe.

Файлы типа \*.com содержат только исполняемый код без дополнительной информации о программе, формируются в загрузочном виде и не требуют настройки. Весь код, данные и стек такой программы располагаются в одном сегменте, имеют длину не более 64 Кб и служат для организации простых модулей, ориентированных на модели памяти tiny и small (приложение 1).

Файлы типа \*.exe могут иметь произвольную длину, они содержат заголовок, в котором описывается размер файла, требуемый объем памяти и таблица загрузки – список команд с абсолютными адресами, требующих настройки при загрузке в зависимости от размещения программы в памяти.

Структура размещения в памяти файла типа COM показана на рис. 3.3.

|  |  |  |
| --- | --- | --- |
| 64 Кб | ↓ Стек    ↑ Данные и код программы | ←SS:SP |
|  |  |
|  | ←100h 🡨 CS:IP ( директива ORG 100h) |
|  | PSP |  |
|  |  |
| 0 | ← DS, CS, ES, SS |

Рис. 3.3

В начальной части com-файла программы (а также и exe-файла) MS DOS размещает специальный блок – префикс сегмента программы ПСП (PSP - рrogram segment prefix), который содержит информацию для доступа программы к параметрам командной строки, к среде окружения, для реакции программы на критические ошибки и управляющие команды типа Ctrl+C. В начальной части PSP размещена команда вызова обработчика прерывания для завершения программы и возврата в DOS. Так как после загрузки все сегментные регистры, включая CS, указывают на начало PSP, а IP = 0, то программа не может исполняться, начиная с этого адреса, и первой командой делают ORG 100h , устанавливающуую CS:IP на конец PSP.

Структура размещения в памяти файла типа EXE показана на рис. 3.4ю мых файлов. сразу за данной.., а состав ряда полей ПСП – в табл. 3.1.

SS:SP

Стек

SS:00

Данные

DS (сюда его необходимо установить)

Код

100h CS:00

PSP

DS (начальное положение), ES

Рис.3.4

Таблица 3.1. Состав основных полей префикса сегмента программы

|  |  |  |
| --- | --- | --- |
| 0h | DW | Команда INT 20 ( 16-ный код: CD 20) - вызов прерывания DOS для завершения программы и возврата в DOS |
| 2h | DW | Размер доступной для программы памяти в параграфах |
| 0Eh | DD | Адрес обработчика прерывания по Ctrl^Break (INT 23h) |
| 12h | DD | Адрес обработчика прерывания по критической ошибке (INT 24h) |
| 2Ch | DW | Значение сегментного адреса среды окружения |
| 80h | 64W | DTA –буферная область данных / адрес начала командной строки программы |

# 3.3.4. Режимы адресации памяти в архитектуре Intel Х86

Большинство команд процессора Intel Х86 выполняются с аргументами, которые принято называть *операндами.* Операнды в программе могут задаваться следующим образом:

* в регистрах общего назначения;
* непосредственно в коде команды;
* в ячейках памяти, задаваемых в команде прямо или косвенно;
* в портах ввода-вывода.

Для указания места расположения операнда используются 8 режимов адресации, использование которых иллюстрируется в таблице 3.2.

**1. Регистровая адресация**

Операнды могут располагаться в любых регистрах общего назначения и сегментных регистрах. В этом случае в операторе программы (на языке ассемблера) указывается название соответствующего регистра.

**2. Непосредственная адресация**

Некоторые команды (пересылки, все арифметические команды, кроме деления) по­зволяют указывать один из операндов непосредственно в операторе про­граммы.

**3. Прямая адресация**

Если известен адрес операнда, располагающегося в памяти, можно ис­пользовать этот адрес. В реальных программах обычно для задания статических переменных используют директивы определения данных, которые позволяют ссылаться на статические пере­менные не по адресу, а по имени.

Если селектор сегмента данных находится в DS, имя сегментного регистра при прямой адресации можно не указывать, так как DS используется по умолчанию. Прямая адресация иногда называется ад­ресацией по смещению.

**4. Косвенная адресация**

Адрес операнда в памяти можно не указывать непосредственно, а хранить в любом регистре. До процессоров i80386 для этого можно было использовать только регистры ВХ, SI, DI и ВР, но потом эти ограничения были сняты и адрес операнда разрешили считывать также и из ЕАХ, ЕВХ, ЕСХ, EDX, ESI, EDI**,** ЕВР и ESP (но не из AX, CX, DX или SP напрямую – надо исполь­зовать ЕАХ, ЕСХ, EDX, ESP соответственно или предварительно скопи­ровать смещение в ВХ, S1, DI или ВР). Как и в случае прямой адресации, DS используется по умолчанию, но не во всех случаях: если смещение берут из регистров ESP, ЕВР или ВР, то в качестве сегментного регистра используется SS. В реальном режиме можно свободно пользоваться всеми 32-битными регистрами, надо толь­ко следить, чтобы их содержимое не превышало границ 16-битного слова.

**5-6. Базовая или индексная адресация.**

Та­кая форма адресации используется в тех случаях, когда в регистре находится адрес начала структуры данных, а доступ надо осуществить к какому-нибудь элементу этой структуры. Другое важное применение адресации по базе со сдвигом – доступ из подпрограммы к параметрам, переданным в кадре стека, используя регистр ВР (ЕВР) в качестве базы и но­мер параметра в качестве смещения.

До процессора i80386 в качестве базового регистра можно было использовать только регистры ВХ, ВР, SI или DI и сдвиг мог быть только байтом или словом (со знаком). Начиная с процессоров i80386 и старше, можно допол­нительно использовать ЕАХ, ЕВХ, ЕСХ, EDX, ЕВР, ESP, ESI и EDI, так же как и для обычной косвенной адресации. С помощью этого метода можно организовывать доступ к одномерным массивам байт: смещение соответствует адресу начала массива, а число в регистре – индексу эле­мента массива, который надо использовать. Очевидно, что если массив состоит не из байт, а из слов, придется умножать базовый регистр на два, а если из двойных слов – на четыре. Для этого предусмотрен следующий специальный метод адресации.

**7. Индексная адресация с масштабированием**

Этот метод адресации полностью идентичен предыдущему, за исключе­нием того, что с его помощью можно прочитать элемент массива слов, двойных слов или учетверенных слов, просто поместив номер элемента в регистр

mov ax, [esi\*2]+2

Множитель, который может быть равен 1, 2, 4 или 8, соответствует размеру элемента массива – байту, слову, двойному слову, учетверенно­му слову соответственно. Из регистров в этом варианте адресации мож­но использовать только ЕАХ, ЕВХ, ЕСХ, EDX, ESI, EDI, ЕВР, ESP, но не **SI,** DI, ВР или SP, которые можно было использовать в предыдущих ва­риантах.

**8. Адресация по базе с индексированием и масштабированием**

Это самая полная возможная схема адресации, в которую входят все случаи, рассмотренные ранее, как частные. Смещение может быть байтом, словом или двойным словом. Если ESP или ЕВР используются в роли базового регистра, селектор сегмента операн­да берется по умолчанию из регистра SS, во всех остальных случаях – из DS.

Таблица 3.2. Использование режимов адресации в архитектуре Intel Х86

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Режим адресации | | Описание в Ассемблере | Регистр сегмента (по умолчанию) | Пример использования |
| Код | Название |
| 0 | Регистровая | EAX/AX/AL | − | MOV EAX, EDX ; DEC CX  MOV AL, CH ; PUSH DS  IN AL, DX |
| 1 | Непосредственная | Данное в виде константы (номер порта ввода-вывода) | − | MOV AX, 1000h; ADD AL, -30h AND EAX, 0000FFFFh  OUT 21h, AL |
| 2 | Прямая | Имя (метка) сме- щения в памяти | DS | MOV BL, Mem\_B1  MOV AX, OFFSET Table |
| 3 | Косвенно-регистровая | [BX], [SI],  [BP],  [DI],  [EAX] и др. | DS  SS  DS(ES)  DS | MOV AL, [SI]  MOV CX, [BP]  MOV AX, ES:[BX]  ADD EAX, [EDX] |
| 4 | Базовая | [BX] + смещение,  [BP] + смещение | DS  SS | MOV AX, CS:[BX] +4  MOV CX, PAR\_TAB[BP] |
| 5 | Индексная | [SI] + смещение,  [DI] + смещение | DS  DS(ES) | CMP ‘A’, STR1[SI]  MOV AL, BYT\_TAB[DI] |
| 6 | Базово-индексная | BX] [SI] + смещ.,  BX] [DI] + смещ.,  [BP] [SI] + смещ.,  [BP] [DI] + смещ. | DS  DS  SS  SS | MOV AX, ES:VALUE[BX][DI] |
| 7 | Индексная с масштабированием | [ERg\* m] + смещ. | DS  SS – для EBP,ESP | MOV CX, WORD\_TAB[ESI\*2] |
| 8 | Базово-индексная с масштабированием | [ERg1] [ERg2\* m] + смещение | DS  SS – для EBP,ESP | MOV BX, [EDX][ECX\*2] + 8 |

**Примечания:**

Базовая адресация применяется для работы со строками или записями, при этом в базовый регистр заносится начало структуры или записи, а смещение задает начало некоторого поля записи или структуры (регистр BP используется по умолчанию для доступа к параметрам процедур через кадр стека). Индексная адресация применяется для доступа к элементам однородных (обычно одномерных) массивов, смещение задает начало элемента этого массива. Базово-индексная адресация используется при работе с элементами полей записи и для работы с двумерными массивами.

# 3.3.5. Краткая характеристика системы команд процессоров Intel Х86

***Формат команды***  представлен в табл. 3.3.

Таблица 3.3

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Префиксы | Переопределе-ние сегмента | Код операции (КОП) | Режим адресации | МИБ | Смещение | Данные |
| 0/1/2\*)/3\*) | 0/1 | 1/2\*) | 0/1 | 0/1\*) | 0/1/2/4\*) | 0/1/2/4\*) |

В первой строке табл. 3.3 указывается имя поля команды, во второй – длина поля в байтах. Знаком \*)  помечены значения длины поля, используемые, начиная с процессора i80386. Максимальная длина команды для процессора i8086 равна 6 байт.

Поле префиксов в процессоре i8086 состоит из 1 байта и может задавать префикс повторения команды, который в ассемблере обозначается как REP (повторять), REPE (повторять поравну), REPNE (повторять не поравно) или префикс LOCK – запрет доступа к шине на время выполнения команды. Более подробно префиксы поясняются в прил. 1 при описании команд строковой обработки. Начиная с процессора i80386, также добавляются однобайтовые префикс размера адреса и префикс размера операнда.

Поле переопределения сегмента используется для жесткого задания регистра сегмента, участвующего в формировании исполнительного адреса, вместо регистра, принятого по умолчанию.

Поле КОП – единственное поле, которое не может быть пустым, оно определяет код (вид) операции, которая должна быть выполнена процессором и тип обрабатываемых данных (для процессора i8086 – байт или слово). Для процессора i8086 поле является однобайтовым, а начиная с процессора i80386 – двухбайтовым.

Поле режима адресации служит для задания режима адресации, места размещения операнда: в регистре или в памяти конкретного используемого регистра.

Поле МИБ (масштаб, индекс, база) является расширением поля режима адресации, используемым начиная с процессора i80386 и задающим при формировании исполнительного адреса операнда масштабный коэффициент, индексный регистр и регистр базы.

Поле смещение содержит смещение адреса памяти при использовании прямой адресации.

Поле данные содержит значение операнда при непосредственной адресации.

Все команды процессора i8086 можно разделить на следующие группы:

1. команды передачи данных;
2. команды арифметических операций над целыми числами;
3. логические команды;
4. сдвиговые команды;
5. команды обработки строк;
6. команды передачи управления;
7. команды прерываний;
8. команды управления флагами;
9. команды управления состоянием процессора;
10. команды плавающей арифметики;
11. команды мультимедийных расширений (ММХ – MultiMedia eXtension);
12. команды потокового расширения (SSE – Streaming SIMD Extension).

# 3.3.6 .Арифметическая обработка чисел с использованием математического сопроцессора

Арифметическая обработка числовых данных обычно выполняется с использованием математического сопроцессора (FPU – Floating Point Unit, NPR – Numeric PRocessor), который сначала выполнялся в виде отдельной микросхемы (i8087 – i80387), а начиная с процессора i80486DX встраивается в состав основного процессора. Сопроцессор называется так потому, что может работать параллельно с процессором после инициализации. Языки высокого уровня используют его непосредственно, а ассемблер порождает ESC команды.

Независимо от наличия сопроцессора, выполнение команд FPU может быть осуществлено тремя способами:

1. С использованием библиотеки альтернативной математики: считается, что сопроцессор отсутствует и выполнение команд FPU моделируется на уровне операций основного процессора.
2. С использованием библиотеки эмулятора: автоматически определяется наличие сопроцессора, и если он есть, то выполняет команды FPU, а иначе их выполнение эмулируется (моделируется на уровне микро-операций) основным процессором.
3. При отсутствии математического сопроцессора возникает прерывание и выполнение программы прекращается.

Первый способ – самый медленный и сейчас практически не применяется. Второй способ не всегда совместим с некоторыми резидентными программами (одни и те же прерывания используются для эмулятора и резидентных программ). Третий способ самый быстрый и сейчас является основным.

***Назначение математического сопроцессора***

Расширение вычислительных возможностей основного процессора – выполнение арифметических операций над целыми и вещественными числами с точностью до 18 десятичных разрядов, вычисление основных математических функций (экспоненты, логарифмы и тригонометрические) и т.д. Применение сопроцессора повышает производительность вычислений в сотни раз.

***Типы данных*** ***математического сопроцессора***

Сопроцессор поддерживает 7 типов данных: три целых (16 бит – Word Integer, 32 бит – Short Integer и 64 бит– Long Integer), 80-битные двоично-десятичные целые (Packed Decimal) и три формата с плавающей запятой, представленые в табл. 3.4.

Таблица 3.4

|  |  |  |
| --- | --- | --- |
| Разрядность (порядка-p/мантиссы-m) | Точность в десятичных разрядах | Диапазон изменения |
| 32 (8/24) Короткое вещественное | 6 / 7 | 10-38 - 1037 |
| 64 (11/53) Длинное вещественное | 15 / 16 | 10-308 - 10307 |
| 80 (15/65) Расширенное вещественное | 18 / 19 | 10-4932 - 104931 |

Сопроцессор выполняет все вычисленя в 80-битном раширенном формате, а 32-битный и 64-битный форматы используются для обмена данными с основным процессором и памятью.

Кроме обычных чисел сопроцессор использует несколько специальных данных, получаемых при выполнении операций:

p m

Положительная бесконечность 0 | 1 … 1 00 … 0

Отрицательная бесконечность 1 | 1 … 1 00 … 0

Неопределенность 1 | 1 … 1 10 … 0

Не число 0 | 1 … 1 1Х…Х , где Х…Х ≠ 0

***Регистры*** ***математического сопроцессора***

Сопроцессор предоставляет для хранения и обработки данных восемь дополнительных 80-битных регистров R0–-R7, организованных в виде закольцованного аппаратного стека ST(0) – ST(7), вершина которого обозна- чается ST, ST(0) или TOP, а более глубокие регистры ST(1) – ST(7). Так, например, если ST = R5, то ST(1) = R6, ST(2) = R7, ST(3) = R0 и т. д.

Кроме того, сопроцессор использует пять вспомогательных регистров:

1. Регистр управления CR – задает режим обработки данных: маскирование ошибок (некорректная операция, деление на 0, переполнение и т.д.), точность обработки (расширенная, двойная, одинарная), способы округления (к ближайшему числу, к нулю, к +∞ или к -∞).
2. Регистр состояния SR – содержит: флаги особых случаев, возникающих в результате выполнения операций (IE - некорректная операция, DE - денормализованный операнд, ZE – деление на ноль, OE – переполнение, UE – антипереполнение, PE – неточный результат); флаги условий, возникающие при операциях сравнения; поле указателя вершины стека ST или TOP; бит B занятости сопроцессора.
3. Регистр тегов TW – содержит двухбитовое поле для каждого из восьми числовых регистров сопроцессора

TW(i) ST(i)

00 вещественное число, не равное нулю

01 вещественное число, равное нулю

10 не число

11 не инициализировано

1. Регистр указателя команды FIP – содержит адрес последней выполненной команды.
2. Регистр указателя операнда DIP – содержит адрес операнда последней выполненной команды.

Два последних регистра используются обработчиком исключений при анализе вызвавшей его команды.

При программировании обработки выражений в сопроцессоре они представляются в виде польской инверсной записи (ПОЛИЗ или RPN – Reversed Poland Notation). Любое выражение преобразуетмя к постфиксному виду (бесскобочная запись).

Примеры:

1. f:= (a + b) \* pi – c преобразуется к виду ab + pi \* c – f :=
2. f:= atan ( sqrt (x2 / (x2 - 1) ) преобразуется к виду xx \* xx \* 1 - / sqrt atan f :=

Фрагмент программы на Ассемблере, реализующей с помощью FPU вычисление выражения из первого примера, имеет вид.

Data Segment

a DQ 2.5

b DQ 6.0

c DQ 3.5

f DQ ?

Data EndS

Code Segment

Assume cs : Code, ds : Data

Public f

Expression Proc Far

Fld a ; a 🡪 st(0)

Fld b ; b 🡪 st(0), a 🡪 st(1)

Fadd ; st(0) + st(1) 🡪 st(0) или (a+b) 🡪 st(0)

Fld pi ; pi 🡪 st(0), (a+b) 🡪 st(1)

Fmnl ; st(0) \* st(1) 🡪 st(0) или (a+b)\*pi 🡪 st(0)

Fld c ; c 🡪 st(0), (a+b)\*pi 🡪 st(1)

Fsub ; st(0) – st(1) 🡪 st(0) или (a+b)\*pi - c 🡪 st(0)

Fstp f ; f:= st(0); st(1) 🡪 st(0)

Ret

Expression EndP

Code EndS

Краткие сведения по программированию на языке Ассемблера IBM PC, используемом здесь и далее для иллюстрации управления обработкой данных в ЭВМ, приведены в приложении 2.

# Организация прерываний в процессорах Intel X86

В архитектуре процессоров Intel X86 предусмотрены особые случаи, когда процессор прерывает выполнение текущей программы и передает управление программе, обрабатывающей возникшую ситуацию. Такие особые ситуации назыаются прерываниями и используются как механизм асинхронного взаимодействия процессов, одновременно выполняемых в вычислительной системе, и как еще один способ вызова подпрограмм. Весь программный интерфейс прикладных программ с функциями операционной системы DOS и сервисами BIOS реализуется именно на основе прерываний.

***Прерывания*** бывают двух видов:

1) ***программные***, вызываемые по команде процессора, и называемые ***исключениями;***

2) ***аппаратные***, вызываемые внешним по отношению к программе сигналом (например, поступающим от внешнего устройства) и называемые просто ***прерываниями***.

***Исключения*** делятся на три типа: ошибки, ловушки и остановы. ***Ошибка*** происходит до выполнения команды, например, если такой команды не существует, или выполняется обращение к некоторой привилегированной команде или запрещенной для доступа области данных. Адрес возврата в этом случае указывает на ошибочную команду. ***Ловушка***– прерывание, возникающее после выполнения команды (например, для организации режима пошагового выполнения программы под управлением отладчика). Адрес возврата указывает на следующую команду. ***Останов*** – ситуация с неопределенным результатом. Возврат может вообще не происходить.

Команды вызова прерываний **INT n**, получившие свое название до деления особых ситуаций на прерывания и исключения, по существу являются исключениями типа ловушки, поскольку сохраняемый по ним адрес возврата указывает на следующую команду прерываемой программы.

***Аппаратные прерывания*** – прерывания, поступающие от внешних устройств или аппаратных средств процессора асинхронно по отношению к выполняемой программе. Делятся на следующие группы:

*1. Прерывания низкого уровня.*

Номера веторов прерываний: NВП= 0…1Fh :

- прерывания от схем процессора 00..07 (0 – деление на ноль; 1 – пошаговый режим; 2 – немаскируемое прерывание; 3 – точка останова; 4 – прерывание по переполнению; 5 – печать содержимого экрана, либо прерывание по команде BOUND; 6 – прерывание по отсутствию команды; 7 – прерывание по отсутствию FPU).

- прерывания от контроллера прерываний (микросхема 8259) 8…0Fh (8 – системный таймер;  
9 – клавиатура; 0Ah – обслуживание видеоадаптера; 0Eh – обслуживание жесткого диска).

- прерывания BIOS 0Ah…1Fh (0Ah – обмен данными с дисплеем; 0Bh – возвращение объема памяти; 0Ch – обмен данными с диском; 0Dh – последовательный порт ввода вывода и т.д.).

*2. Прерывания среднего уровня.*

NВП=20h…5Fh

Здесь прерывание с номером 21h представляет набор функций ОС для работы с файлами управления задачами, выделения и освобождения памяти, работы с виртуальной памятью).

Прерывания пользователей.

NВП=60h…7Fh (прерывания от 70h используются для различных устройств).

*3. Прерывания языков высокого уровня.*

**Уровни приоритета**

Прерывания, обслуживаемые контроллером прерываний 8259, имеют 16 уровней приоритета с запросами IRQ0 - IRQ15. Самый высокий уровень приоритета имеет запрос IRQ0.

IRQ0 (INT 8) – прерывания от системного таймера;

IRQ1 (INT 9) – прерывания от клавиатуры;

IRQ2 – размножитель приоритетных уровней;

IRQ8 (INT 70) – прерывания от часов реального времени;

IRQ9 (INT 0Аh) – прерывание обратного хода луча и звуковой карты;

IRQ10- IRQ12 – резерв для дополнительных устройств;

IRQ13 (INT 2) – прерывания по ошибке FPU;

IRQ14 (INT 76h) и IRQ15 (INT 77h) – прерывания от контроллеров жесткого диска IDE1, IDE2.

IRQ3 (INT 0Bh) – прерывания от последовательного порта COM2;

IRQ4 (INT 0Ch) – прерывания от последовательного порта COM1;

IRQ5 (INT 0Dh) – прерывание от LPT2 используется дополнительным устройствами;

IRQ6 (INT 0Eh) – прерывания от прерывания от магнитного диска;

IRQ7 (INT 0Fh) – прерывания от LPT1 используется дополнительным устройствами.

**Маскируемые прерывания**

Целью маскирования или запрета прерываний являются запрещения прерывания выполнения критических (по доступу к ресурсам) частей программы или запрещение на некоторое время долго обслуживаемых прерываний, например, в системах реального времени.

Способы реализации.

1. Общее маскирование.

Управление реализуется командами CLI, STI, которые соответственно сбрасывают в ноль или устанавливают в единицу флаг разрешения прерывания IF.

2) Выборочное маскирование.

Засылка определенного кода в регистр маски контроллера 8259. В этом контроллере имеется три основных регистра:

IRR – регистр запроса прерывания;

ISR – регистр обслуживания прерывания (порт 20h);

IMR – регистр маскирования прерывания (порт 21h.

К регистру IRR подключены все линии запросов IRQ0..IRQ15. Регистр ISR хранит приоритет текущего обслуживаемого прерывания. Если запрос прерывания, поступивший в регистр IRR не замаскирован, то происходит сравнение приоритетов PRIRR и PRISR .Если PRIRR>PRISR,то поступивший запрос принимается на обслуживание.

Например, запрет прерываний от жесткого диска обеспечивается командами

mov al, 01000000b; маскируются запросы прерывания от жесткого диска

out 21h

------

mov al, 0

out 21h

***Разработка собственных прерываний***

Причины: необходимость создания собственной подпрограммы, резидентной в памяти и доступной из любой программы; необходимость дополнения функций существующих прерываний; использование холостых прерываний, телом которых является IRET.

Существует два способа заполнения вектора прерывания адресом своего обработчика:

- низкоуровневый – командой mov записать по адресу вектора прерывания адрес сегмента и смещения обработчика;

- с использованием функций операционной системы: функции 25 и 35 прерывания Int 21h позволяют устанавливать новое и получать старое значение адреса обработчика вектора прерывания.

**Пример.** Пусть нам требуется установить собственный обработчик прерывания по номеру N=60

Data Segment

old\_cs dw 0; буфер для хранения

old\_ip dw 0; старого вектора прерывания (ВП)

---------

old\_vp dd 0;

Data ENDS

Code Segment

;сохранение адреса старого обработчика

mov ax, 3560h

int 21; старый\_ВП\_cs🡪es, старый\_ВП\_ip🡪bx

mov old\_cs, es

mov old\_ip, bx

;задание адреса нового обработчика в ВП 60h

push ds

mov dx, offset New\_sub

mov ax, seg New\_sub

mov ds, ax

mov ax, 2560h

int 21h

pop ds

;новый обработчик прерывания 60h

New\_sub proc far

push ax

; тело нового обработчика

pop ax

mov al, 20 ; загрузка в регистр ISR кода 20

out 20h ; для разрешения прерываний более низкого уровня

iret

---------

Final EQU $

---------

New\_sub ENDP

;восстановление старого ВП

lds dx, DWORD PTR OLD\_CS

mov ax, 2560h

int 21h

Возможные проблемы:

* если данные передаются через память, нужно тщательно следить за содержимым регистра DS; лучше данные передавать через регистры или стек;
* если возможно прерывание обработчика через Ctrl+Break, необходимо предусмотреть восстановление адреса старого обработчика;
* требуется минимизировать код обработчика прерывания, так как на время его выполнения может быть запрещено выполнение других прерываний.

***Перекрытие обработчика прерываний***

Существующие обработчики прерываний DOS и BIOS сложно поддаются модификации на уровне исходных кодов и для добавления новых функций требуется реализовать следующий механизм:

* создать новый обработчик прерываний (реализующий дополнительные функции), который вызывает старый (системный), размещенный по новому неиспользованному ранее вектору в диапазоне 60h…70h;
* перенести адрес старого обработчика прерываний в новый вектор прерывания;
* изменить вектор прерывания с системным номером таким образом, чтобы он указывал на новый обработчик прерывания;
* завершить программу установки нового обработчика и оставить ее резидентной в памяти.

Возврат после завершения старого обработчика может происходить либо в новый обработчик командами

push f

call old\_handler;

если дополнительные функции реализуются после выполнения старого обработчика, либо в вызывающую процедуру командой

jmp cs:old\_handler;

если дополнительные функции реализуются до выполнения старого обработчика.

***Разработка резидентных обработчиков прерываний***

Такие обработчики называются TSR-процедуры (Terminate and Stay Resident – завершить и оставить в памяти). Для оставления обработчика в памяти перед его завершением командой ret следует вызвать прерывания int 27h (более старая версия) или int 31h (более новая версия).

Резидентный обработчик обычно пишется в виде модуля типа com и для его разработки необходимо:

* наличие свободного вектора прерывания и указание метки конца обработчика для int 27h (определение длины обработчика +100PSP);
* для int 31h длина обработчика задается в параграфах.

Для минимизации длины кода обработчика инициализирующую часть выносят за его пределы.

Cod\_s Segment

Begin: jmp short set\_up; переход на инициализацию

Rezid\_h: proc far

push ds

;тело процедуры обработчика прерывания

pop ds

iret

Final EQU $; текущее значение счетчика размещения

Rezid\_h ENDP

Set\_up: mov dx, offset Rezid\_h

mov ax, 2568h; задание свободного ВП с номером 68h

int 21h

;завершение с оставлением в памяти

lea dx, Final

int 27h

ret

Cods ENDS

# Эволюция микроархитектуры Intel X86

Первый однокристальный четырехбитный микропроцессор 4004 фирма Intel разработала в 1971 году с целью использования в качестве универсального контроллера для калькуляторов. Он содержал 2300 транзисторов на кристалле кремния площадью 12 мм2, был изготовлен по 10 мкм технологии и работал с тактовой частотой 750 кГц. Успех процессора 4004 вдохновил Intel на создание 8-битного микропроцессора 8008, а затем и 8080, который, в свою очередь, превратился в 16-битные процессоры 8086 (1978 год) и 80286 (1982 год). В 1985 году Intel представила процессор 80386, который расширил архитектуру 8086 и превратил ее в 32-битную, ознаменовав появление архитектуры Intel X86.

В таблице 3.5показана эволюция микропроцессоров Intel X86. За 40 лет после создания 4004, линейные размеры транзисторов уменьшились в 160 раз, число транзисторов на кристалле увеличилось на пять порядков, а рабочая частота выросла почти на четыре порядка. Ни в одной другой области техники никогда не было такого удивительного прогресса в столь короткий промежуток времени.

Таблица 3.5**Процессор**

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| Процессор | Год | Технология (мкм) | Число транз-ов (млн) | Частота (Мгц) | Микроархитектура |
| 80386 | 1985 | 1.5–1.0 | 0,275 | 16–25 | Многотактная |
| 80486 | 1989 | 1.0–0.6 | 1,2 | 25–100 | Конвейерная |
| Pentium | 1993 | 0.8–0.35 | 3,2–4,5 | 60–300 | Суперскалярная |
| Pentium II | 1997 | 0.35–0.25 | 7,5 | 233–450 | Внеочередная версия |
| Pentium III | 1999 | 0.25–0.18 | 9,5–28 | 450–1400 | Внеочередная версия |
| Pentium 4 | 2001 | 0.18–0.09 | 42–178 | 1400–3730 | Внеочередная версия |
| Pentium М | 2003 | 0.13–0.09 | 77–140 | 900–2130 | Внеочередная версия |
| Core Duo | 2005 | 0.065 | 152 | 1500–2160 | Двухядерная |
| Core 2 Duo | 2006 | 0.065–0.045 | 167–410 | 1800–3300 | Двухядерная |
| Core i3-i7 | 2009 | 0.045–0.032 | 382–731 | 2530–3460 | Многоядерная |

Intel 80386 был многотактный процессор. Программируемая логическая матрица (ПЛА), содержащая *микрокод*, использовалась устройством управления для того, чтобы определить порядок перехода между состояниями управляющего автомата. Блок управления памятью управлял доступом к внешней памяти.

У процессора Intel 80486 производительность значительно улучшилась благодаря использованию конвейерной обработки. По-прежнему выделяются тракт данных, устройство управления и ПЛА с микрокодом.

Процессор Pentium использовал суперскалярную архитектуру и мог запускать на выполнение две команды одновременно. Pentium использовал раздельные кэши команд и данных. Он также использовал предсказание переходов для уменьшения потерь производительности из-за команд условного перехода.

Процессоры Pentium Pro, Pentium II и Pentium III имели общую микроархитектуру под кодовым названием P6, обеспечивавшую внеочередное выполнение команд. Сложные команды IntelX86 разбивались на одну или несколько микроопераций (МОп), похожих на команды MIPS. Затем эти МОп выполнялись на быстром вычислительном ядре с 11-стадийным конвейером, обеспечивавшем внеочередное выполнение команд.

В Pentium III 32-битный тракт данных назван целочисленным функциональным блоком (ФБ). Тракт данных для операций над числами с плавающей запятой (ПЗ) назван блоком вычислений с ПЗ. В процессоре также имеется ФБ SIMD для пакетной арифметики с целыми числами и числами с ПЗ. Площадь кристалла для организации внеочередного запуска команд на выполнение, оказалась больше, чем площадь для самого выполнения команд. Кэши команд и данных были увеличены до 16 Кб каждый и на кристалл также была добавлена более большая, но и более медленная кэш-память второго уровня размером 256 Кб.

Процессор Pentium 4 был очередным процессором с внеочередным выполнением команд, но с конвейером очень большой длины (сначала конвейер имел 20 стадий, а в поздних версиях – 31 стадию), что позволило достичь частоты, превышающей 3 ГГц. Для дешифрации трех команд за один такт процессор проводил разбиение команд на простые микрооперации и сохранял их в *кэш последовательностей микроопераций*. Более поздние версии Pentium 4 также использовали многопоточность для увеличения пропускной способности процессора при выполнениее нескольких потоков. Процессор Pentium M был усовершенствован за счет увеличения размера кэш-памяти команд и данных до 32 Кбайт, а размера кэш-памяти второго уровня - до двух Мбайт.

Процессор Core Duo представлял собой многоядерный процессор, содержащий два ядра Pentium M, подключенных к общей кэш-памяти второго уровня размером 2 МБ. В 2009 году Intel представила новую микроархитектуру под названием Nehalem как модернизированную версию Core. Эти процессоры, включая Core i3, i5 и i7, реализуют поддержку 64-битных команд. Они имеют от двух до шести ядер, кэш-память 3 уровня размером 3–15 МБ и встроенный контроллер памяти. Некоторые модели поддерживают гиперпоточность (hyperthreading) – так Intel называет многопоточность с двумя активными потоками, которая, с точки зрения пользователя, удваивает количество ядер.

# Управление выполнением команд в компьютерах.

Пример: Пусть требуется описать этапы цикла процессора при реализации команды Аdd ax, Mem1, которая размещается в памяти в двух 16-битных словах в виде

|  |  |  |
| --- | --- | --- |
| КОП  Add | АХ, режим адресации 2-го операнда | 🡨(K+0 |
| 15 8 7 0  Mem 1 | | 🡨(K+2 |

Опишем на уровне элементарных операций основные этапы выполнения команды, применительно к структурной схеме процессора с памятью, показанной на рис. 3.1.

1. Выборка и дешифрация первого слова команды.

ПСч 🡪 РАП ; переслать значение программного счетчика в регистр адреса контроллера памяти

Код “Чт” 🡪 КонтрЗУ ; загрузить код операции «Чтение» в контроллер памяти

“0” 🡪 ГОТЗУ, пуск ЗУ ; сбросить флаг «Готовность ЗУ», запустить операцию в памяти

Проверить условие:

ГОТЗУ = 1

Если условие «ложно», то ожидать завершения операции в памяти, иначе продолжить дальше.

РДП 🡪 РгКом ; переслать содержимое регистра данных контроллера памяти в регистр команд процессора;

(ПСч)+2 🡪 (ПСч) ; подготовить в ПСч адрес следующего слова команды;

РгКом.КОП🡪ДешКОП ; поле КОП (код опреации) регистра команд подать на вход дешифратора операций;

РгКом.РА🡪Деш.РA ; поле РА (режим адресации) регистра команд подать на вход дешифратора режимов адресации.

1. Выборка второго слова команды.

ПСч 🡪 РАП | Эту последовательность операций

Код “ЧТ” 🡪 КонтрЗУ | обозначим в дальнейшем

“0” 🡪 ГОТЗУ, пуск ЗУ | как “ЧТ”ЗУ

Ожидание ГОТЗУ = 1 |

РДП 🡪 БуфРг ; переслать содержимое регистра данных контроллера памяти в БуфРг (буферный регистр процессора)

ПСч + 2 🡪 ПСч ; подготовить в ПСч адрес следующей команды.

3. Выборка операнда из Mem1.

БуфРг 🡪 РАП

“ЧТ”ЗУ

РДП 🡪 РгBх АЛУ ; переслать содержимое регистра данных контроллера памяти в РгBх – входной регистр АЛУ.

4. Исполнение операции.

РгAX +РгBх 🡪 РгАХ ; суммирование аккумулятора РгАХ и РгBх АЛУ

Учет переносов

{Qi} 🡪 РгССП ; установка флажков в регистре Слова Состояния Процессора по результату завершения операции.

Для описания элементарных операций, составляющих процесс выполнения команды, будем использовать язык межрегистровых передач (ЯМРП) [6], любой оператор которого описывается в следующем виде:

<ОП\_ЯМРП> : : = [ метка ] условие : список \_ действий

где: условие – булевское выражение, содержащее временную привязку списка действий к такту процессора; список действий – набор микроопераций, выполняемых параллельно в данном такте; микрооперация – действие, выполняемое аппаратными средствами за один такт генератора.

Совокупность микроопераций, выполняемых за один такт, называют микрокомандой.

Последовательность микрокоманд, реализующих всю команду, называют микропрограммой.

Примеры описания на языке МРП элементарных операций, использовавшихся выше при реализации этапов выполнения команды, приведены в табл. 4.1

Таблица 4.1.

|  |  |
| --- | --- |
| *Выполняемые операции* | *Описание операций на ЯМРП* |
| 1. ПCч 🡪 РАП | ВЫБК.& ГОТЗУ & Т1: ПСч 🡪 ША (У1)  ША 🡪 РАП (У2) |
| 2. Код “Чт.” 🡪 Контр. ЗУ  0 🡪 ГОТЗУ | ВЫБК.& ГОТЗУ & Т2: “Чт” 🡪 ШУ (УЗ)  ШУ 🡪 РгУ КонтрЗУ (У4)  “0” 🡪 РгСостКонтрЗУ.ГОТЗУ (У5) |
| 3. РДП 🡪 Рг ком.  ПСч + 2 🡪 ПСч  Рг Ком. КОП 🡪 ДешКОП  Рг Ком.РежА 🡪 ДешРА | ВЫБК.& ГОТЗУ & Т3: РДП 🡪 ШД (У6)  ШД 🡪 Рг Ком. (У7)  ПСч + 2 🡪 ПСч. (У8)  Рг Ком.КОП 🡪 ДешКОП (У9)  Рг Ком.РежА 🡪 ДешРА (У10) |

В табл. 4.1, наряду с использовавшимися выше, применяются обозначения: ВЫБК – этап выборки команды, Тi – i-й такт генератора, Уi – i-й сигнал управления, ША – шина адреса, ШУ – шина управления, ШД – шина данных.

Для формирования сигналов Уi, управляющих выполнением элементарных операций в процессорах, используются два основных способа:

1. Аппаратный, реализуемый на основе жесткой логики (Wired Logic).
2. Микропрограммный, реализуемый на основе программируемой логики (Stored /Programmed Logic).

## Аппаратный способ формирования управляющих сигналов

Аппаратный способ формирования управляющих сигналов (УС) основывается на использовании автомата управления и реализации его схемным (аппаратным) образом. Под автоматом понимается абстрактный дискретный процесс, который определяется тремя множествами и двумя функциями. К используемым множествам относятся:

1. Множество состояний процесса S = {S1, S2, . . . , Sk}.

Это множество конечно и поэтому автоматы также называются конечными.

1. Множество входных воздействий X = {X1, X2, . . . , Xn} автомата, поступающих в дискретные моменты времени ti. В качестве входных воздействий автомата для управления выполнением команд ВМ рассматриваются: коды операций, режимы адресации, тактовые сигналы Ti, состояния устройств Qi и т.п.
2. Множество выходных сигналов Y = {Y1, Y2, . . . , Ym} автомата, также формируемых в дискретные моменты времени ti.

Часто множество X называют входным алфавитом автомата, а множество Y – его выходным алфавитом.

Функциями, описывающими поведение автомата являются:

1. Функция переходов δ, определяющая правила перехода автомата из одного состояния в другое:

T: S x X 🡪 S | S (t + Δ) = δ[s(t),x(t)], где Δ > 0 – длительность такта.

1. Функция выходов λ, определяющая правила формирования выходных сигналов автомата:

| λ[s(t), x(t)], эта функция соответствует поведению

R: S x X 🡪 Y | Y (t + Δ) = < автомата Мили (Mealy).

| λ[S (t + Δ)], эта функция соответствует поведению

автомата Мура (Moore).

Вид функции выходов зависит от типа автомата управления – для автомата Мили сигнал управления вырабатывается в момент перехода автомата из одного состояния в другое и является импульсным, для автомата Мура – сигнал управления вырабатывается после перехода автомата в некоторое состояния и является потенциальным. Структурная схема синхронного автомата управления представлена на рис. 4.1.

Входы х1 Комбинационная y1 Выходы

схема

хn ym

Текущее Si Элементы памяти S’iСледующее

состояние (задержка на Δ) состояние

Рис. 4.1

Комбинационная схема – это логическая схема, у которой выходные сигналы определяются входными сигналами в текущий момент времени. Элементы памяти обеспечивают задержку на один такт Δ. Поэтому переменные следующего состояния S’iбудут определять текущее состояние Siв следующий момент времени t + Δ. Отметим основные преимущества и недостатки аппаратного способа формирования УС:

1. Основным достоинством аппаратного способа формирования УС является максимально достижимое быстродействие управления выполнением команд процессор.
2. Основной недостаток аппаратного способа формирования УС является жесткость структуры автомата управления, требующая его полного переконструирования даже при небольшом изменении состава входных или выходных сигналов, функций переходов или выходов.
3. Синтез и реализация автомата с большим количеством состояний является сложной научно-технической проблемой.
4. Нерегулярность структуры автомата затрудняет его реализацию с помощью серийно выпускаемых интегральных схем (ИС) и требует их выполнения в заказном варианте.

## Микропрограммный способ формирования управляющих сигналов

Микропрограммный способ формирования УС основан на том, что входные сигналы автомата управления можно представлять как адреса некоторой памяти, ячейки которой содержат требуемые комбинации выходных сигналов. Поэтому формирование сигналов управления в текущий момент времени можно представить как выборку по n-битному адресу, каждый бит которого соответствует текущему значению одного из n входных сигналов Xi, одного из 2n слов памяти, содержащего требуемую m-битную комбинацию, соответствующую текущим значениям каждого из m выходных сигналов Yj. Тогда проблема формирования сигналов управления выполнением команд процессора сводится к организации *последовательности выборок слов из памяти* по адресам, соответствующим последовательности комбинаций входных сигналов, которая обеспечит требуемую последовательность комбинаций значений управляющих сигналов.

Поскольку набор микроопераций, выполняемых в текущем такте с помощью сформированных в этом такте управляющих сигналов, называется микрокомандой, а последовательность микрокоманд образует микропрограмму выполнения машинной команды, то память, хранящая набор микропрограмм для выполнения каждой команды процессора, называется микропрограммной памятью, а данный способ управления выполнением комад – микропрограммным управлением (МПУ). Идею построения МПУ впервые предложил M. Wilks (Кембридж) в 50-х годах прошлого века, но активная реализация МПУ началась только в середине 60-х. г.г. по мере развития технологии разработки ИС (в частности, схем памяти).

Структурная схема устройства микропрограммного управления представлена на рис. 4.2.

КОП

РгКом

РгАМК

n

МПЗУ Схема ГТ

синхронизации

m

РгМК

ОпЧМК(m`) (m``)АЧМК

ФАСлМК

ФормУС

{Уi} {Qi} из АЛУ и РгСостВУ

Рис. 4.2.

На рисунке приняты следующие обозначения: МПЗУ – микропрограммное запоминающее устройство (память микропрограмм), РгКом и КОП – соответственно регистр команд (машинных) и его поле кода операции, РгАМК – регистр адреса текущей микрокоманды длиной n бит, РгМК – регистр текущей микрокоманды длиной m бит, ОпЧМК и АЧМК – соответственно операционная (длиной m’) и адресная (длиной m”) части микрокоманды, ФАСлМК – формирователь адреса следующей микрокоманды, ФормУС – формирователь управляющих сигналов Уi, ГТ – генератор тактов, РгСостВУ – регистр состояния внешнего устройства.

Код операции выполняемой машинной команды подается в РгАМК и определяет адрес в МПЗУ начала микропрограммы, реализующей эту машинную команду. На РгМК выбирается первая микрокоманда, операционная часть которой поступает на формирователь сигналов, управляющих выполнением микроопераций, входящих в состав этой МК, а адресная часть поступает на формирователь адреса следующей МК. Адрес следующей МК либо принудительно задается в коде текущей МК, либо формируется в зависимости от условий {Qi} завершения текущей МК. Сформированный адрес следующей МК поступает на РгАМК и из МПЗУ выбирается следующая МК. Этот процесс повторяется до завершения микропрограммы выполняемой машинной команды, после чего на РгКом выбирается следующая машинная команда, инициирующая выполнение микропрограммы этой команды.Основными достоинствами микропрограммного управления являются:

1. Регулярная структура устройства управления позволяет *реализовать* *его на основе серийных БИС.*
2. *Большая гибкость* в плане изменения или специализации набора команд ВМ путем замены (в случае ПЗУ) или перезаписи (в случае ППЗУ) микропрограммной памяти.
3. Возможность *рационального распределения аппаратного и микропрограммного управления* порождает семейство машин с одним набором команд, но разной производительностью.
4. Микропрограммное управление предоставляет возможность *эмуляции* на микропрограммном уровне новых архитектур машин на имеющейся инструментальной машине.
5. Микропрограммная реализация системных программ (компиляторы, файловые системы) значительно повышает производительность ВМ и широко используется в суперкомпьютерах.

Основные недостатки микропрограммного управления:

1. *Снижение производительности* процессора из-за замедления выполнения каждой микрокоманды, связанного с обращением к МПЗУ.
2. *Увеличение площади кристалла*, необходимой для размещения устройства МПУ.

**Способы кодирования микрокоманд**

Обычно число различных микроопераций в несколько раз превышает число машинных команд. Кроме того, в составе микрокоманды требуется указывать прямой адрес следующей микрокоманды в МПЗУ. Это приводит к тому, что длина микрокоманды Lмкможет достигать больших размеров (до 200 бит и более). В то же время эффективно использовать все 200 бит микрокоманды невозможно. Поэтому возрастает роль выбираемого способа кодирования микрокоманд. Различают следующие основные способы:

1. *Горизонтальное или унитарное кодирование* (по существу, отсутствие какого-либо кодирования).

Как видно из рис. 4.3, здесь каждый бит ОпЧМК определяет выполнение только одной микрооперации (МОп). Это позволяет в одной МК задавать любые сочетания МОп и соответствующих им УС Уi , обеспечивая их параллельное выполнение. Кроме того, отсутствует необходимость в декодировании ОпЧМК. В то же время длина ОпЧМК определяется максимально возможным числом микроопераций

LОпЧМК = (NМОп)max

Это основной недостаток горизонтального кодирования, увеличивающий расход памяти в МПЗУ при низкой эффективности использования разрядов ОпЧМК в конкретной МК.

ОпЧМК

У1 У2 Уm`

Рис. 4.3

Достоинствами горизонтального кодирования являются:

1. простота и высокая скорость формирования управляющих сигналов;
2. максимальный параллелизм выполнения МОп.
3. *Вертикальное кодирование микрокоманд* .

В случае вертикального кодирования каждой микрооперации присваивается отдельная двоичная комбинация, например, соответствующая двоичному коду ее номера в общем списке возможных МОп. Рарядность этого двоичного кода будет определять длину ОпЧМК в соответствии с выражением

LОпЧМК = Int [log2 (NМОп)max] +1, где Int(Х) – целая часть числа Х .

При этом ОпЧМК будет иметь минимальную длину и это приведет к уменьшению затрат памяти на хранение микропрограмм. С другой стороны, для распознавания кода микрооперации необходим дешифратор МК, преобразующий код МОп в соответствующий УС и требующий на это некоторое время. Кроме того, в каждой МК можно задать только 1 МОп, что увеличивает длину микропрограммы и время ее реализации.

1. *Смешанное кодирование микрокоманд.*

В этом случае весь набор микроопераций делится на группы, связанные с управлением конкретными устройствами (АЛУ, память и т.п.), как показано на рис.4.4. В каждую группу включаются взаимно несовместные МОп, которые не встречаются вместе в одной МК. При этом УС, формируемые в одном и том же такте, оказываются в разных группах и могут выполняться параллельно.

Управление регистрами Управление АЛУ Управление памятью

\_\_\_

ОпЧМК

⇓ n1 ⇓n2 ⇓n3

ДШ 1 ДШ 2 ДШ 3

↓ … ↓ ↓ … ↓ ↓ … ↓

{Yi} {Yi} {Yi}

2 n1 2 n2  2 n3 (число

выходов ДШ)

Рис. 4.4

Внутри каждой группы МОп кодируются вертикальным способом и двоичный код группы поступает на соответствующий дешифратор, где выполняется его декодирование. Такой способ смешанного кодирования называется горизонтально-вертикальным, так как выбор группы осуществляется по горизонтальному принципу, а внутри группы используется вертикальное кодирование.

При использовании К независимых групп длина ОпЧМК определяется соотношением

К

LОпЧМК = ∑ ni , где ni = Int[Log2(NМОп)i] + 1

i=1

Такой способ смешанного кодирования сочетает достоинства и снижает влияние недостатков чисто горизонтального (большая длина МК при низкой эффективности использования разрядов ОпЧМК) и чисто вертикального (увеличение времени выполнения микропрограммы) способов кодирования.

**Способы адресации микрокоманд***.*

В зависимости от способа указания адреса очередной МК различают устройства МПУ с принудительным и естественным порядком следования МК. В случае ***принудительной адресации МК*** адрес следующей МК указывется непосредственно в текущей МК. Этот адрес может задаваться безусловно или выбираться в зависимости от условия, определяемого по признакам (флажкам) выполнения текущей МК, что позволяет реализовать ветвления в микропрограммах. ***Естественный порядок следования МК*** предусматривает выборку очередной МК из ячейки памяти с адресом на 1 больше адреса текущей МК. В этом случае роль формирователя адреса следующей МК может выполнять обычный счетчик, необходимость в адресной части МК фактически отпадает и МК может содержать только операционную часть (операционная МК или ОМК). Но в этом случае в микропрограмме (МПМ) нельзя реализовать ветвления. Для обеспечения ветвлений в МПМ надо ввести дополнительный формат МК – управляющие (УМК), содержащие только поле логического условия (ЛУ) и поле адреса очередной МК, к которой осуществляется переход при выполнении этого условия. В случае невыполнения ЛУ адрес следующей МК равен текущему, увеличенному на 1. Безусловные переходы реализуются УМК с нулевым полем ЛУ. Для различения ОМК и УМК в обоих форматах надо применять однобитовое поле признака.

# Компьютеры с сокращенным набором команд

Компютеры с сокращенным набором команд (КСНК) – более известные по английской аббревиатуре как RISC-компьютеры (RISC – Reduced Instruction Set Computer) – воплощают направление развития архитектуры ВМ, связанное с возвращением к принципам аппаратного управления выполнением команд с целью повышения производительности.

Система команд первого и частично второго поколений машин содержали не более пятидесяти команд. Основная проблема, по которой набор команд не расширялся, – это цена аппаратуры (и управляющая, и обрабатывающая части процессора реализовывались аппаратно), а также необходимость программирования в кодах (программист не мог запомнить большое количество команд). Период доминирования аппаратного управления 50-е – начало 60-х годов, можно назвать «эрой аппаратчиков».

С середины 60-х до 80-х годов доминирует микропрограммное управление выполнением команд, воплощающее «эру программистов», основным лозунгом которой было: «Больше команд хороших и разных!». Этот лозунг соответствовал основным требованиям к процессорам того времени:

1. Минимизация длины кода программы
2. Упрощение реализации компиляторов за счет снижения семантического разрыва между ЯВУ и машинными командами.

Это вызвало рост набора команд компьютеров за счет увеличения их сложности и увеличения числа форматов от ~50 до ~300 команд (рекордсменом был Vaх11/780, у него было 303 команды). Компьютеры с большим набором команд и разнообразием их форматов получили название CISC-компьютеров (Complex Instruction Set Computer – машина со сложным набором команд). Для них характерно увеличение сложности и соответственно размеров микропрограммного устройства управления, которое интерпретировало выполнение этих команд. К тому времени благодаря технологическим достижениям тактовая частота процессоров стала достигать 100 Мгц и повышение производительности требовало размещения всех частей процессора на одном кристалле для сокращения длины соединений его элементов. В то же время микропрограммное управление из-за своей сложности стало занимать до шестидесяти процентов площади кристалла, что либо не допускало использования эффективных средств арифметической обработки данных, либо требовало размещения частей процессора на разных кристаллах. Все это приводило к существенному ограничению производительности, увеличивало сроки разработки и снижало выход годных кристаллов.

В 80-х годах рядом исследователей было замечено, что при выполнении большинства программ наиболее активно используется около 30% сравнительно простых команд арифметики и управления. Постепенно стало формироваться направление развития архитектуры компьютеров, требующее чтобы система команд процессора содержала минимальный набор наиболее часто используемых и наиболее простых команд (возврат к примерно 50 командам). Это направление получает название компьютеров с сокращенным набором команд или RISC-компьютеров и имеет лозунг: «Меньше команд, выше скорость выполнения!».

В результате в конце 80-х гг. благодаря развитию технологии производства СБИС и их удешевлению, а также развитию методов и опыта разработки оптимизирующих компиляторов, постепенно сложились основные принципы (или законы) RISC-архитектур:

1. Основной набор команд не должен интерпретироваться микрокомандами, а должен выполняться аппаратным обеспечением.
2. Все команды должны иметь одинаковую длину и минимальное число форматов (обычно не более 2–3), это упрощает логику управления при выборе и при исполнении команды.
3. Любая команда основного набора должна выполняться за один машинный цикл, обратно пропорциональный тактовой частоте процессора (стандартом является команда сложения регистра с регистром, занимающая от 3–10 нс); это достигается одновременным (параллельным) выполнением максимально возможного числа команд путем конвейеризации или использования нескольких обрабатывающих узлов
4. Обращение к памяти производиться только по специально выделенным командам работы с памятью типа: Load – загрузка и Store – сохранение, а вся обработка данных должна вестись в регистровом формате; при этом количество регистров должно быть велико (100 и более).
5. Система команд должна обеспечивать поддержку компиляции с конкретного языка программирования (компиляторы для RISC на порядок сложнее, чем компиляторы для CISC).

Немного истории: Идея создания RISC-компьютера впервые была реализована в машинах Cray–1. В 1975 г. сотрудник фирмы IBM John Cook впервые попытался применить RISC-архитектуру при создании модели IBM7095, производительность при этом повысилось в два – три раза. Само название RISC появилось в середине восьмидесятых годах в университете Беркли, где под руководством Дэвида Паттерсона и Карло Секвина была создана машина RISC–1, а затем последовал RISC–2, позже принятый за основу машин семейства SPARC фирмы Sun. Почти одновременно в Стэнфордском университете был разработан процессор MIPS, положивший начало серийному выпуску машин R4000 – R10000 фирмы MIPS.

Затем почти все ведущие производители ЭВМ стали разрабатывать и выпускать машины на основе RISC-архитектур:

1. Hewlett - Packard – PA7xxx – PA9xxx (PA – Precision Architecture)
2. DEC – Alpha 21xxx
3. IBM + Apple – Power PC .

*Формат команд и структура процессора RISC–1*

В большинстве RISC-процессоров команды являются трехадресными (рис. 5.1)

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 7 | 1 | 5 | 5 | 1 | 13 |
| КОП | Усл | Dest | SRC1 | IMM | SRC2 |
| 31 25 | 24 | 23 19 | 18 14 | 13 | 12 0 |

Рис. 5.1

КОП – код операции.

Усл – бит условия (для команд переходов).

Dest – номер регистра назначения (длина пять бит – NPOH = 32).

SRC1 – номер регистра-источника 1.

SRC2 – номер регистра или непосредственного значения источника 2:

если IMM = 1 ⇒ SRC2 – непосредственное данное, если IMM = 0 ⇒ SRC2 – регистр.

В процессоре RISC-1 используется два вида формата команды.

1. Rd ⇐ Rs1 oper S2– для выпонения операций обработки;
2. Rd ⇔ M((Rs1) + S2) – для выпонения обмена с памятью.

Шина процессор-память

Кэш команд

АЛУ

Буфер предвыборки

и логика управления Блок Блок

Рг1 Рг2

Логика Регистр Логика

выборки резуль- выборки

Рг1 тата Рг2

Структура процессора RISC -1 показана на рис. 5.2.

Рис. 5.2

Регистровый формат команд обработки данных облегчает реализацию конвейерного исполнения команд, так как исключает конфликты при обращении к памяти.

*Пример*. Пусть требуется вычислить выражение E = (A + B) x (C + D)

1. Двухадресная обработка команд в CISC-компьютерах с использованием ячеек памяти.

Add b, a

Add d, c

Mull d, b

Store e, d

║ ВК | ДШ | ОА | ВО | ИСП | ЗР ║ ВК | | |

║ ВК | ДШ | ОА | ВО | ИСП | …… | ЗР ║ | |

║ ВК | ДШ | ОА | …… | …… | …… | ВО | | |

║ …… | …… | …… | …… | …… | …… | ВК | | |

ВК – выборка команды, ДШ – дешифрация, ОА – обработка адресов, ВО – выборка операндов,

ИСП – исполнение операции, ЗР – запись результата, **…….** – такт ожидания.

1. Трехадресная обработка команд в RISC-компьютерах с использованием регистров.

S1 S2 d

Add R1, R2, R6

Add R3, R4, R7

Mull R6, R7, R5

║ ВК | ДШ | ИСП ║

║ ВК | ДШ | ИСП ║

║ ВК | ДШ | ИСП ║

Основная проблема: при большом количестве используемых регистров: надо сохранять их в памяти при переключениях с подпрограммы на подпрограмму. Решение проблемы сохранения и восстановления набора регистров при вызове подпрограмм предлагается реализовать путем организации так называемых “Окон перекрытия регистров” – MORS – Multiple Overlapping Register Set (Rolodex в RISC–1).

Сто тридцать восемь регистров в RISC-1 распределялись между 8 программами (по 32 регистра) как показано на рис. 5.3.

Физические регистры Логические регистры

Проц. А

R137 R31A

HIGH A

R132 R26A

R131 R25A

Окно А LOCAL A

R122 R16A Проц. B

R121 R15A R31B

LOW A / HIGH B

R116 R10A R26B

R115 R25B

Окно В LOCAL B

R106 R16B Проц. С

R105 R15B R31C

LOW B / HIGH C

R100 R10B R26C

R99 R25C

Окно С LOCAL C

R90 R16C

R89 R15C

LOW C

R84 R10C

**. . .**

R9

Global R

R0

Рис. 5.3

Передача параметров (до 6 штук) между процедурами реализуется без затрат времени просто за счет

перекрытия логических регистров (физические регистры совпадают).

Недостатки:

1. Ограниченное число параметров при передаче через регистры.
2. Ограниченное число подпрограмм, которым могут предоставляться регистровые окна.

*Арифметические особенности RISC-процессоров*

В RISC-процессорах имеется возможность увеличения аппаратной поддержки арифметических операций благодаря уменьшению места на кристалле для размещения управляющей части процессора.

Все RISC-процессоры по размерам обрабатываемых данных удовлетворяют стандарту ANSI:

* с фиксированной запятой – 32 бит
* с плавающей запятой – 64 бит

В арифметико-логическом устройстве процессора широко применяются схемные методы ускорения выполнением операций (например, одновременная обработка нескольких разрядов в одном такте, использование групповых переносов и т.д.).

Рассмотрим пример сравнения использования команд CISC- и RISC-процессоров на примере компьютеров VAX и SPARC.

|  |  |  |
| --- | --- | --- |
|  | VAX  (CISC) | SPARC  (RISC) |
| **Статика** |  |  |
| Число строк | 1 | 1.5 |
| Операции обращения к памяти | 1 | 1.5 |
| Фиксированная арифметика | 1.5 | 1 |
| Плавающая арифметика | 1 | 3…4 |
| Переходы | 1 | 2.5…3 |
| **Динамика** |  |  |
| Число выполненных строк | 1 | 3…4 |
| Обращения к памяти | 1 | 3…5 |
| Фиксированная арифметика | 2…2.5 | 1 |
| Плавающая арифметика | 1 | 2…2.5 |
| Переходы | 1 | 1…1.5 |

Время выполнения программы упрощенно можно оценить по следующему выражению

Tпрограммы = Nкоманды x Cтакт/ком x Tтакт,

где Tтакт – длительность такта, и для параметров CISC- и RISC-процессоров справедливы соотношения:

NкомRISC = (1.5 - 2.0) \* NкомCISC,

Cтакт/ком. CISC= (5 - 10) \* Cтакт/ком. RISC,

TCISC = (3 - 4) \* TRISC.

Тогда для времен выполнения программ с большим числом арифметических операций будет справедливо соотношение

Тпрогр.CISC = (10 - 20)Тпрогр.RISC.

Основные ***достоинства RISC- процессоров:***

1. Повышение производительности обработки программ вычислительных задач.
2. Благодаря использованию простых команд и минимума их форматов сокращается время разработки RISC-процессора.
3. Улучшение технологичности RISC-процессоров благодаря большей свободе в размещении их элементов на кристалле интегральной схемы и повышение вероятности выхода годных схем.

***Недостатки RISC- процессоров:***

1. Нарушение основных принципов программирования:

а) Минимум длины исполняемого кода программы.

б) Снижение семантического разрыва между исходным описанием и машинным кодом.

1. Сложность построения компилятора, поскольку программа с языка высокого уровня должна транслироваться в микрокод с оптимизацией использования регистров.
2. Высокие требования к быстродействию памяти.

Кроме того, следует учитывать, что сейчас производительность вычислительной системы в большой степени определяется не процессором, а скоростью передачи данных по шинам и протоколами сетевого взаимодействия. Гораздо важнее требование совместимости с созданным ранее программным обеспечением, которому многие RISC-процессоры не удовлетворяют, что сдерживает их распространение.

# Организация памяти в компьютере

# 6.1. Назначение и основные характеристики памяти

Память используется для хранения следующих объектов:

1. Компьютерные программы.
2. Состояния всех устройств.
3. Данные (постоянные или переменные).

В памяти недопустима обработка данных и, следовательно, применимы всего две операции: выборка или чтение (информация не разрушается) и запись (предыдущая информация разрушается).

Память понимается как линейная последовательность ячеек, наделенных адресами, по которым осуществляется доступ к содержимому. Различают единицы адресуемой информации:

1. МАЕП – минимально адресуемая единица памяти.

В зависимости от вида данных:

1 бит (флаги слова состояния процессора, внешних устройств);

1 байт (арифметические данные, команды).

1. Слово – наибольшая длина данного, выбираемого за одно обращение (16, 32, 64, 128 бит).

Основные характеристики памяти:

1. **Емкость** (обозначается С) с диапазоном: 1 байт (регистр памяти) – n\*100 Г байт (винчестер, оптический диск).
2. **Быстродействие** (обозначается Т) с диапазоном: n\* 1нс (регистровая память) – n\* 10 с (магнитная лента, оптический диск).

Чем больше емкость памяти, тем обычно меньше ее быстродействие. Для преодоления противоречия емкости и быстродействия используется иерархическая организация памяти.

Основные параметры, характеризующие быстродействие памяти:

а) t ВЫБОРКИ – время от запуска памяти для считывания данного и до появления его в буферном регистре (не включает установку и дешифрацию адреса).

б) t ОБРАЩЕНИЯ – среднее время, затраченное на обращение к памяти в двух последовательных циклах чтения и записи данных по разным адресам (включая время задания адреса и его дешифрации).

Как правило, выполняется соотношение tОБР ≥ 2t ВЫБ.

1. **Надежность** – зависит от возникновения сбоев при считывании или записи данных и обеспечивается с помощью средств контроля (обнаружения и исправления ошибок):

а) Parity control – контроль по четности, позволяет обнаружить одиночные ошибки (в одном бите);

б) ECC (error checking and correction control) – контроль с использованием корректирующих кодов, использует два дополнительных бита. Позволяет обнаружить двойную ошибку или скорректировать одиночную ошибку.

1. **Плотность записи** (бит /см2), зависит от типа среды хранения информации, наиболее высокая плотность у оптических накопителей.
2. **Стоимость хранения** одного бита – важна для пользователя с финансовой точки зрения.

# 6.2. Основные среды хранения информации

1. Магнитная среда.

Исторически самые первые запоминающие устройства использовали магнитную среду, где в качестве носителя информации использовались магнитные материалы, в настоящее время применяются только в устройствах внешней памяти из-за низкого быстродействия.

1. Среда с накоплением зарядов.

В данном случае в качестве элемента памяти используются конденсатор и транзистор, позволяющие хранить один бит информации. В зависимости от вида материалов, различают: биполярную полупро-водниковую память (более быстрая) и память на МОП-структурах (металл – окисел – полупроводник), более медленную, но дешевую. Из-за разряда конденсатора информация хранится краковременно и ее надо регенерировать каждые 5-10 мсек.

1. Память на активных элементах с усилительными свойствами.

В качестве элементов памяти используются триггеры – электронные схемы с двумя устойчивыми состояниями, а сами структуры хранения называются регистрами (самый быстрый вид памяти, но имеет малую емкость). При наличии питающего напряжения информация хранится сколь угодно долго.

1. Оптические запоминающие устройства.

Запись информации осуществляется лазерным лучом, а представление информации определяется либо различными свойствами прохождения луча через среду, либо поляризацией материала среды (достаточно высокая плотность записи и малая цена хранения одного бита информации).

# 6.3. Методы доступа к данным.

Запоминающие устройства (ЗУ) отличаются способом доступа к данным.

1. Последовательный доступ. Ориентирован на хранение последовательности блоков данных (записей) и для доступа к нужному элементу (байту или слову) надо прочитать все предшествующие ему данные. Время доступа зависит от положения записи среди других и положения элемента в записи. Примером может служить ЗУ на магнитной ленте.
2. Прямой доступ. Доступ к записи осуществляется адресно, а к элементу внутри записи - последовательно. Соответственно, время доступа - переменное в небольших пределах. Примером может служить ЗУ на магнитных дисках.
3. Произвольный доступ. Каждая ячейка памяти имеет свой физический адрес. Обращение к любой ячейке производится в произвольной очередности и занимает одинаковое время. Примеры – основная память типа RAM (Random Access Memory) и постоянные ЗУ – память типа ROM (Read Only Memory).
4. Ассоциативный доступ (АЗУ) – доступ к ячейкам памяти осуществляется по их содержимому, а не по адресу путем параллельного сравнения содержимого всех ячеек с заданным образцом.

# 6.4. Память с произвольным доступом (ППД)

Память с произвольным доступом имеет структуру, показанную на рис. 6.1.

Шина адреса

ш

Рг А и

н

а

Дш А у

п

Контроллер р

Накопитель управления а

чтением/ в записью л

БРГД е

н

и

Шина данных я

я

РгА – регистр адреса, ДшА – дешифратор адреса, БРгД – буферный регистр данных.

Рис. 6.1

Накопитель ППД организован в виде матрицы ячеек, состоящих из запоминающего элемента (ЗЭ), хранящего 1 бит информации и имеющего свой адрес, определяемый адресом строки (RAS - Row Address) и адресом столбца (CAS – Column Address). Они хранятся в регистрах адреса строки и адреса столбца, связанных со своими дешифраторами (Дш), к выходам которых подсоединены ЗЭ матрицы, расположенные на пересечении соответсвующих строки и столбца. Совокупность ЗЭ, логических схем выбора строк и столбцов и логики интерфейса образуют интегральную микросхему (ИМС) памяти.

В случае реализации ЗЭ на основе конденсатора и запирающего ключа ППД называется динамической (DRAM – Dynamic RAM) и требует регенерации, а в случае реализации ЗЭ на основе триггера ППД называется статической (SRAM – Static RAM) и сохраняет информацию, пока подается питание. Динамическая ППД - более дешевая и медленная, но имеет большую емкость, а статическая ППД - более быстрая, дорогая и ввиду малой емкости применяется только как быстрая буферная память (память типа Кэш).

*Режимы работы ППД*

Для повышения быстродействия обращения к памяти применяются различные режимы работы ИМС памяти, позволяющие: исключить повторные указания адреса строки, выполнять передачу данных по обоим фронтам импульса спхронизации и выполнять групповую (пакетную) передачу данных, требующую задания адреса столбца только для 1-го данного пакета. В качестве примеров ускоренных режимов обращения к памяти можно привести:

1. Режим быстрого страничного доступа FPM (Fast Page Mode) - режим, при котором при многократном последовательном обращении к одной и той же строке номер строки задается только первый раз, а кроме того адрес столбца меняется по заднему фронту сигнала RAS (системная шина меньше двадцати пяти мегагерц).
2. Режим удвоенной скорости DDR (Double Data Rate) – передача данных по обоим фронтам импульса синхронизации.
3. EDO (Extended Data Out) - режим при котором адресация нового столбца осуществляется до завершения предыдущего, производительность повышается примерно вдвое (системная шина от пятидесяти до шестидесяти мегагерц).
4. SDRAM (Synchronous Dynamic RAM), ориентирована на обработку пакетов из четырех 32-битных или 64-битных слов, отличается общей синхронизацией управляющих сигналов от общего сигнала (системная шина выше семидесяти пяти мегагерц).
5. RDRAM (Rambus Direct RAM) – режим, сочетающий DDR с асинхронным блочно-ориентированным протоколом передачи, при котором передача данных между контроллером и памятью передается пакетами.

Более подробные сведения по различным режимам обращения к ППД можно получить в [1,2].

## 6.5. Блочная организация основной памяти.

Емкость основной памяти в современных компьютерах слишком велика, чтобы ее можно было реализовать на одной ИМС. Кроме того, разрядность ячеек ИМС памяти, как правило, меньше разрядности слов в ВМ. Поэтому для получения основной памяти требуемой разрядности несколько ИМС объединяют в модуль памяти. Затем несколько модулей объединяют в банк памяти, имеющий требуемую разрядность, но еще недостаточную емкость. Наконец, несколько банков памяти объединяют для получения основной памяти требуемой емкости. Объединение банков производится по блочному принципу. При этом для памяти, состоящей из В банков адрес А ячейки памяти преобразуется в пару (b, w), где b – номер банка, а w – адрес ячейки внутри банка. Распределение разрядов адреса А между частями b и w может распределяться следующим образом:

1. Старшие разряды адреса А определяют номер банка b, а младшие – адрес w ячейки в банке; такая организация называется чисто блочной;
2. Номер банка определяется по правилу b = A mod B, а адрес ячейки w = A div B; такая блочная организация называется циклической и для нее младшие разряды адреса А определяют номер банка b, а старшие – адрес w ячейки в банке.

Примеры структур блочной организации ОП для памяти емкостью 512 слов, состоящей из 4-х банков, показаны для чисто блочной схемы - на рис. 6.2, а для циклической блочная схемы - на рис. 6.3.

А w- адрес ОП (0-511)

Дешифратор номера банка памяти

b - номер банка (0-3)

|  |
| --- |
| Банк 0 |
| 0 |
| … |
| 127 |

|  |
| --- |
| Банк 1 |
| 128 |
| … |
| 255 |

А8 А7 А6 … А0

|  |
| --- |
| Банк 2 |
| 256 |
| … |
| 383 |

|  |
| --- |
| Банк 3 |
| 384 |
| … |
| 511 |

РА Памяти

Блок управления

Запрос А8..А0

Мультиплексор

ШУ ША ШД

A = (b , w), b = [7 - 8 ] – адрес банка, w = [0 - 6] - адрес слова в банке

Рис. 6.2 Чисто блочная организация ОП

В функциональном отношении такая память может рассматриваться как единое ЗУ, емкость которого равна суммарной емкости банков, а быстродействие соответствует быстродействию одного банка.

Дешифратор номера банка памяти

А1, А0

А8..А2

РАП-3

РАП-2

РАП-1

РАП-0

|  |
| --- |
| Банк 0 |
| 0 |
| … |
| 508 |

|  |
| --- |
| Банк 1 |
| 1 |
| … |
| 509 |

Блок упра- вле-ния

|  |
| --- |
| Банк 2 |
| 2 |
| … |
| 510 |

|  |
| --- |
| Банк 3 |
| 3 |
| … |
| 511 |

РгД-3

РгД-2

РгД-1

РгД-0

Зап А8..А0

Мультиплексор

рос

ШУ ША

ШД

A = (w, b), b = [0 - 1] - адрес банка, w = [2 - 8] - адрес слова в банке

Рис.6.3 Циклическая блочная организация ОП (память с чередованием адресов)

Циклическая блочная организация использует принцип расслоения памяти или чередование адресов (interleaving) для параллельного доступа к смежным ячейкам памяти, размещаемым в различных банках. Поскольку в каждом такте на шине адреса задается адрес только одной ячейки, квазипараллеьное обращение производится со сдвигом на 1 такт. Адрес ячейки запоминается в индивидуальном регистре адреса (РАП) и дальнейшие операции по доступу к ячейкам каждого банка протекают независимо. Среднее время доступа к ОП может сокращаться почти в В раз. Поэтому в функциональном отношении такая память может рассматриваться как единое ЗУ, емкость которого равна суммарной емкости банков, а быстродействие соответствует быстродействию одного банка, помноженному на число банков.

## 6.6. Постоянные запоминающие устройства (ПЗУ - ROM)

Используется для хранения фиксированных микропрограмм, подпрограмм и констант (BIOS). По технологии изготовления и способу использования различают:

1. МПЗУ (масочное ПЗУ) – устройство, в котором запись информации осуществляется фирмой-изготовителем путем выжигания связей (участков) в процессе изготовления модуля памяти.
2. ППЗУ (программируемое ПЗУ (PROM)) – устройство, которое в исходном виде поставляяется пользователю, и он сам прошивает необходимые связи для записи требуемой информации с помощью специального прибора – программатора). После такой процедуры ППЗУ не может больше перепрошиваться.
3. ПППЗУ (перепрограммируемое ПЗУ (EPROM)) – это устройство аналогично ППЗУ, только с возможностью стирания информации ультрафиолетом в течение длительного времени (более 10 минут) и затем записи новой информации.

## 6.7. Ассоциативные запоминающие устройства (АЗУ)

В отличие от других видов памяти доступ к информации в АЗУ осуществляется не по адресу размещения данного, а по содержимому – значению самого данного или его части. При этом в АЗУ хранимая информация сравнивается с некоторым образцом и проверяется их соответствие. Образец, по которому производится поиск информации, называется ассоциативным признаком. На рис. 6.4 показан вариант построения АЗУ, включающий:

1. память данных Х для хранения N m-разрядных слов;
2. регистр ассоциативного признака (разрядностью k ≤ m) для создания образца поиска;
3. регистр маски, позволяющий исключить из признака поиска определенные биты;
4. схемы совпадения, реализующие параллельное сравнение каждого битавсех слов памяти данных с соответствующим битомпризнака поиска и выработки сигналов совпадения;
5. регистр совпадений, каждый бит которого соответствует одной из ячеек памяти и в него заносится 1, если все разряды этой ячейки совпали с одноименными разрядами признака поиска;
6. комбинационная схема, формирующая сигналы, характеризующие результаты поиска.

Регистр ассоциативного

признака key [1..k], k ≤ m

Адрес считывания

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 1  2  **.**  **.**  **.**  N | 1 2 . . . . . . m | | | |  |
|  |  | **…** |  |
|  |  | **…** |  |
| **. . . . .** | | | |
|  |  | **…** |  |
|  | | | |

Р с

е о

г в

и п

с а

т д

р е

н

и

й

Шифратор

Схемы

cовпадения

i = 1..N, j=1..k

Регистр маски Rm

Комбин схема

конт-роля

ассо-

циации

а0

а1 1..N 1..N

а2

Память данных Х Xi[j] &Rm[j] = key[j] &Rm[j] N-разрядное

(N m-разрядных слов) слово

Рис.6.4. Структура ассоциативного ЗУ

Поскольку результаты поиска могут быть неоднозначными, комбинационная схема контроля ассоциации по содержимому регистра совпадений формирует признаки ai , показывающие, что:

1. а0 - слово не найдено, 2) а1 - найдено только 1слово, 3) а2 - найдено много слов

При считывании данных производится контроль ассоциации и при а0 =1, считывание отменяется,

при а1 =1 считывается слово, на которое указывает 1 в регитсре совпадений, а при а2 = 1 сбрасывается самая старшая 1 в регистре совпадений и извлекается соответствующее ей слово памяти данных. Повторяя последнюю операцию можно считать все слова.

Основными преимуществами АЗУ является высокое быстродействие за счет параллельного поиска и то, что время поиска зависит только от числа разрядов в признаке поиска и скорости опроса разрядов и не зависит от числа ячеек N памяти данных. С другой стороны, большие затраты оборудования на реализацию параллельного сравнения данных с признаком поиска позволяют использовать АЗУ только как буферную память небольшой емкости (чаще всего как Кэш 1-го уровня).

# 6.8. Иерархическая система памяти

Для достижения компромисса между емкостью и быстродействием памяти, а также для снижения влияния разрыва в быстродействии процессора и пмяти, в современных коиьютерах память реализуется в виде иерархической системы, показанной на рис. 6.5. Более высокий уровень ЗУ харктеризуется большим быстродействием, меньшей емкостью и большей стоимостью хранения 1 бита информации.

Иерахическая система памяти состоит из следующих уровней:

1. Сверхоперативная память (СОЗУ), которая реализуется на регистрах процессора, а также Кэш – память 1 уровня размещаются на одном кристалле с процессором и являются наиболее быстрыми видами памяти.
2. Буферная память, создаваемая на основе Кэш – памяти 2 и 3 уровней, вместе с Кэшем 1 уровня служит для согласования скорости процессора и основной памяти. Образует с основной памятью систему буферизованной памяти. Для программиста эта память является прозрачной (скрытой), поэтому и называется кэш-памятью, она реализуется на биполярных элементах и размещается на одной плате с процессором. Для Гарвардской архитектуры буферная память может разделяться на кэш команд и кэш данных.
3. Основная память - блочно организованная память прямого доступа, обеспечивающая хранение системных и пользовательских программ и данных, выполняемых в текущем интервале времени.
4. Дисковый Кэш – буферная память, используемая для согласования быстродействия основной и дисковой памяти, реализуется на полупроводниковых элементах и может быть отдельным ЗУ, включаемым в состав НМЖД, или фрагментом основной памяти.
5. Дисковая магнитная память – медленная (по сравнению с ОП) память большой емкости, размещаемая на жестком диске (винчестере), и служащая либо для хранения программ и данных, не используемых в настоящее время, либо для расширения доступного программисту адресного пространства путем организации совместно с основной памятью системы виртуальной памяти.
6. Архивная память – многотомные накопители информации большого объема, реализуемые на магнитных лентах или оптических дисках. Имеют самое низкое быстродействие и предназначены для долговременного хранения данных без разрушения.

Процессор

(СОЗУ, Кэш1ур.)

Буферная память Система буферизации ОП

(Кэш 2ур.,Кэш 3ур.)

Основная память Система виртуальной памяти

Дисковый Кэш Система буферизации диска

Дисковая

магнитная

память

Оптические

диски

Р

Х

Магнитные И   
 ленты В

А

Рис.6.5. Иерархическая система памяти

В целом следует отметить, что иерархическая организация памяти ведет к уменьшению общей стоимости хранения и доступа к информации при заданном уровне производитльности.

## Организация кэш-памяти.

Использование кэш-памяти основано на свойстве ***локальности*** программ по обращению, имющем три составляющих:

1. Пространственная локальность программ, заключающаяся в том, что при выборке команд из памяти адрес очередной команды либо следует непосредственно за адресом предыдущей, либо находится вблизи него;
2. Пространственная локальность данных, связанная с тем, что за счет широкого использования структурированных данных при обращении к данным, как правило, используются последовательные ячейки памяти;
3. Временная локальность программ, заключающаяся в том, что в течение достаточно длительных интервалов времени исполняемая программа использует сравнительно небольшой диапазон адресов команд и\или небольшой диапазон адресов данных. Это обусловлено наличием в программе циклов и подпрограмм, а также необходимостью длительной обработки массивов данных.

Идея использования кэша как буферной памяти заключается в наличии двух видов памяти:

быстрой памяти малой емкости М1 (n1, tобр1) и медленной памяти большой емкости М2(n2, tобр2), параметры которых: число ячеек - ni и время обращения tобрiхарактеризуются неравенствами

n1 << n2 и t обр1 << t обр2.

Если данные имеются в быстрой кэш-памяти, то они выбираются за время t обр1, а если отсутствуют, то за время t обр1 + t обр2 данные выбираются из основной памяти и одновременно подгружаются в кэш-память.

Если благодаря свойству локальности удается исполняемый фрагмент программы и обрабатываемый массив данных разместить в кэш-памяти, то вероятность 0 < α << 1 отсутствия команд или данных в кэш - памяти удается сделать достаточно малой - обычно α ≈ 0.02…0.05. Тогда среднее время обращения к такой системе буферизованной памяти будет

М {t обр} = (1 - α) \* t обр1 + α \* (t обр1 + t обр2) = t обр1 +α\* t обр2 ≈ t обр1

Поскольку емкость кэш-памяти значительно меньше емкости основной памяти (ОП), то эпизодически происходит обмен информацией между КЭШем и ОП, чтобы в КЭШе оказывалась актуальная на данное время информация. При этом обмен происходит *блоками* одинакового размера, которые в кэш-памяти принято называть *строками*. Когда процессор пытается выбрать слово из памяти, то сначала он ищет это слово в КЭШе и если находит, то выбирает его из КЭШа. Такая ситуация называется *попаданием* (hit), а при отсутствии слова в КЭШе возникает ситуация *промах* ( miss) и слово выбирается из ОП. Одновременно из ОП в кэш-память пересылается блок данных, содержащий это слово.

Так как число блоков ОП больше числа строк КЭШа, строка КЭШа не может быть выделена постоянно одному блоку ОП. Поэтому каждой строке КЭШа соответствует признак (*тег*), показывающий, копия какого блока ОП хранится в ней в данное время. В качестве тега обычно используется часть адреса ОП. При этом для разных типов (уровней) КЭШа применяются различные способы отображения ОП на кэш-память.

Рассмотрим различные способы отображения блоков ОП на кэш-память на следующем примере.

Соп = 256 Кслов=218  слов, Скэш  = 2 Кслов=211  слов, Сблока = 16 слов (С - емкость);

Моп = Nбл.оп. = 256К/16 = 16K = 214 блоков., Мкэш = 2К/16 = 128 = 27 блоков (М – число блоков);

Lадр.оп = 18бит = 14бит (адрес блока ОП) { 7бит (тег) +7бит (строка кэша)} + 4бит (слово в блоке)

Lадр.кэш = 11бит= 7бит (адрес строки кэша) + 4бит (слово в блоке) (L – длина адреса в битах)

**Прямое отображение блоков ОП на кэш-память**

При *прямом отображении* адрес строки i кэш-памяти, на которую может быть отображен блок j ОП, однозначно определяется выражением

**i = j mod Mкэш**

В нашем примере i = j mod 128, где i = [0,127], j = [0,16383] и на строку КЭШа с номером i отображается каждый 128 блок ОП, начиная с блока i , что поясняется на рис. 6.6 . Здесь 14-битный адрес блока ОП разбивается на два поля: 7-битный тег (7 старших разрядов адреса) и 7-битный номер строки кэш-памяти, на которую может быть отображен этот блок ОП. При этом поле тега определяет, какой из списка блоков ОП, закрепленных за данной строкой кэша, сейчас адресуется. Когда блок ОП фактически заносится в соответствующую строку кэш-памяти, в поле тегов этой строки нужно записать тег именно этого блока, в качестве тега служат 7 старших разрядов адреса блока.

Память Память Тег

тегов данных 0 1 2 . . . . . . 127 Строка

|  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 0 | **0** |  | Блок 0 |  | Блок  0 | Блок 128 | Блок 256 | **….…** | Блок 16256 | 0 |
| 1 | **2** | Блок 257 | Блок  1 | Блок 129 | Блок 257 | Блок 16257 | 1 |
| 2 | **1** | Блок 130 | Блок  2 | Блок 130 | Блок 258 | Блок 16258 | 2 |
| …. | **……** | ………. | ……….……….……….………. | | | ………. | …. |
| 126 | **2** | Блок 382 | Блок  126 | Блок 254 | Блок 382 | Блок 16382 | 126 |
| 127 | **127** | Блок 16383 | Блок  127 | Блок 255 | Блок 383 | Блок 16383 | 127 |

7 бит 4 бит

**К э ш п а м я т ь О с н о в н а я п а м я т ь**

Рис.6.6

При несомненной простоте прямого отображения его существенным недостатком является жесткое закрепление строки кэша за определенными блоками ОП. Поэтому при поочередном обращении программы к словам из двух блоков, отображаемых на одну и ту же строку кэша, постоянно будет происходить обновление этой строки, резко снижающее скорость доступа к памяти. Кэш с прямым отображением ввиду своей экономичности используется для построения кэшей 2-го и 3-го уровней сравнительно большого объема.

А**ссоциативное отображение блоков ОП на Кэш-память**

Такой способ отображения, иллюстрируемый рис.6.7, позволяет производить загрузку любого блока ОП в любую строку кэш-памяти. В кэш-памяти используется поле тегов, содержащее 2 тега: тег1 (14 бит), соответствющий адресу блока ОП, и тег2 (7 бит), определяющий адрес блока в КЭШе, а также поле данных, определяющее адрес слова в блоке. Контроллер кэш-памяти выделяет в адресе ОП два поля: поле тегов и поле слова. Поле тега совпадает с 14-битным адресом блока ОП. Для проверки наличия копии блока ОП в кэш-памяти логика управления контроллера кэша должна одновременно сравнить теги 1 всех строк КЭШа на совпадение с полем тега адреса ОП. Это обеспечивается использованием ассоциативной памяти для хранения тегов КЭШа. После нахождения строки КЭШа, тег1 которой совпал с адресом искомого блока ОП, по тегу 2 определяется размещение искомого блока в КЭШе.

Ассоциативное отображение обеспечивает гибкость при выборе строки кэш-памяти для размещения блока ОП, но требует использования дорогостоящей ассоциативной памяти, поэтому применяется только для построения КЭШей 1 уровня (процессорных).

**Наборно-ассоциативное отображение блоков ОП на Кэш-память**

Такой способ отображения сочетает достоинства прямого и ассоциативного способов и позволяет каждому блоку ОП претендовать на одну из нескольких строк кэш-памяти, объединенных в набор (множество). Можно считать, что в этом случае используется несколько параллельно и согласованно работающих каналов прямого отображения: каждому набору строк КЭШа соответствует жестко заданная группа блоков ОП, а в пределах набора контроллеру кэша по ассоциативному способу приходится выбирать, в какую из строк набора помещать очередной блок данных из ОП. Кэш с наборно-ассоциативным отображением может применяться для построения как первичных, так и вторичных кэшей.

Адрес блока Адрес блока

в ОП (14б) в КЭШе (7б)

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| 0 | **20** | **2** | 0  1  2  126  127 | Блок 258 |  | Блок 20 |
| ….. |
| 1 | **258** | **0** | Блок 32 | Блок 32 |
| ….. |
| 2 | **3200** | **126** | Блок 20 | Блок 258 |
| ….. |
| … | **…..** | **…** | ………. | Блок 1600 |
| ….. |
| 126 | **32** | **1** | Блок 3200 | Блок 3200 |
| ….. |
| 127 | **1600** | **127** | Блок 1600 | ….. |
| ….. |

Тег1(14 бит) Тег2(7 бит) (4 бит)

**Т е г и Данные**

**К э ш - п а м я т ь О с н о в н а я п а м я т ь**

Рис.6.7

При использовании кэш-памяти возникает две важных группы проблем:

1. Замещение блока в строке кэш-памяти на новый блок ОП при необходимости загрузки последнего в полностью занятую кэш-память. Эта проблема возникает только для ассоциативного и наборно-ассоциативного способов отбражения блоков ОП на строки кэш-памяти. В настоящее время в основном используется два способа замещения блоков ОП в КЭШе:

1. LRU (Least-Recently-Used) – производится замена в кэш-памяти блока ОП, к которому дольше всего не обращались; этот способ требует поддерживать историю обращения к блокам (с помощью счетчиков).
2. FIFO (Fist-in, Fist-out) или обычная очередь – производится замена в кэш-памяти блока ОП, который загружался раньше всех других; это более дешевая, но не столь эффективная стратегия замены блоков в КЭШе по сравнению с LRU-стратегией.

2. Согласование данных в КЭШе и основной памяти.

1. Store through (Write through) – сквозная запись (одновременная запись данного в блок кэша и в блок основной памяти), при этом происходит трата ресурсов и времени на обновление основной памяти. Достоинство: надежный способ согласования данных.
2. Store In (Write back) – обратная запись, обновление блока ОП происходит только при выгрузке строки из КЭШа в ОП. Достоинство - более высокая производительность. Недостаток - временное различие данных в ОП и в КЭШе может привести к конфликтам (проявляется в многопроцессорных компьютерах с общей памятью).

# 6.10. Организация виртуальной памяти

Виртуальная память – система основной и дисковой памяти, организуемая для расширения адресного пространства, доступного программам пользователей. Для виртуальной памяти различают:

1. ФАП (физическое адресное пространство) – совокупность адресов, соответствующих реально адресуемым физическим ячейкам памяти.
2. ЛАП (ВАП) (логическое или виртуальное адресное пространство) – это совокупность адресов, которая может использоваться для доступа к данным.

Очевидно, что емкость ВАП должна значительно превышать емкость ФАП.

Для обеспечения доступа к ВАП из программ пользователей необходимо установить строгое соответствие между данными, размещаемыми в ОП, и данными, размещенными на диске, отражаемое в специальных таблицах соответствия адресов. Для сокращения длины таблицы соответствия адресов информация, хранящаяся в основной памяти и на диске, должна быть разбита на одинаковые (в обоих видах памяти) блоки, для которых и устанавливается соответствие.

Разбиение происходит по двум способам :

1. Страничный;
2. Сегментный

При первом вся память (основная и дисковая) разбивается на одинаковые по размерам блоки, называемые страницами; разбиение происходит независимо от типа и характера размещаемых данных. Говорят, что страничное разбиение ориентируется на физическую память.

При втором разбиение основной и дисковой памяти происходит на сегменты, как правило, соответствующие логически завершенным объектам задачи (программа, массив данных и т.д.); вследствие этого длина каждого сегмента может быть произвольной. Говорят, что сегментное разбиение имеет логическую ориентацию. Первый способ имеет более простые организацию и стратегию подгрузки и замещения страниц в основной памяти. Для второго способа достоинством является удобство организации защиты информации и коллективного доступа к данным.

*Страничную организацию виртуальной памяти* можно пояснить с помощью схемы, показанной на рис. 6.8.

Виртуальный (логический) адрес (ВА)

Базовый адрес Номер Смещение в Регистр

таблицы страниц страницы странице адреса

(в регистре) + Pва d

Рб

Диск

P

m / d р’

Замещение

**3’** страниц

Таблица соответствия **4’**

адресов (таблица страниц)

d

Основная

память (ФА)

Основная

память (ФА)

**1**

**2’**

Page\_fault Карта диска

Page\_hit

**2,5’**

Страничный

кадр

(фрейм)

**3,6’**

Рис.6.8

Сущность преобразования адресов: ВА p**.**d --> ФА p’**.**d

Признак m/d задает «бит присутствия»: 1 – страница есть в ОП, 0 – страница имеется только на диске.

При замещении страниц в основной памяти используются следующие стратегии:

1. FIFO – заменяется страница ОП, которая была загружена первой из имеющихся в ОП страниц.
2. LRU – заменяется страница ОП, к которой дольше всего не было обращений.
3. WS (work set) – рабочее множество: для конкретных интервалов времени создается совокупность страниц ОП, которые активно используются и не замещаются, остальные можно удалить из памяти.

Приведенная выше схема соответствует принципу прямого соответствия адресов, при котором для любого логического адреса есть свой физический адрес.

Для сокращения длины таблицы страниц и времени доступа к ней используется принцип ассоциативного отображения страниц. В этом случае для хранения адресов наиболее часто используемых страниц используется память типа кеш и обращение к ней происходит по следующей схеме (рис. 3.6)

Такая структура называется буфер страничной трансляции (БСТ).

***Сегментная организация виртуальной памяти***

При сегментной организации ВП строка таблицы сегментов должна содержать специальные атрибуты, задающие не только факт присутствия сегмента в ОП, но также его длину и способ доступа к сегменту.

S

Сущность преобразования адресов:

Атрибуты S’ ВА S**.**d --> ФА S’**.**d,

где операция ‘**.**’ означает конкатенацию

Формат строки таблицы сегментов

m/d L R W E АВП Здесь признак m/d – «бит присутствия»

1 nI 1 1 1 nII

L – длина сегмента; R,W,E – доступность по чтению, записи, выполнению; АВП – адрес во внешней памяти.

Одной из проблем виртуальной памяти является фрагментация виртуальной памяти. Фрагментацию обычно различают внутреннюю и внешнюю. Внутренняя возникает от неполного использованния страницы сегмента и образованию участков памяти, доступ к которым затруднен. Внешняя возникает только при сегментной организации виртуальной памяти из-за того, что удаляемый и размещаемый на его место сегменты имеют разные размеры. Для преодоления фрагментации ОС запускает процедуру, называемую «сборка мусора» для объединения свободных участков памяти в сплошные блоки. Для устранения внешней фрагментации и сокращения длины таблицы страниц применяется сегментно-страничная организация (рис. 6.9).

S P d

Номер Номер Смещение

сегмента страницы в странице

+ ФА1

БА Сегмента Таблица стр.1

+

БА ТС1 +

i

ФАi

БА ТС i +

Таблица сегментов Таблица стр. i

Рис.6.9

Сегмент рассматривается не как целый, а разбивается на страницы, именно части страниц будут теряться при фрагментации. Таблицу сегментов также не рассматривают как указатель на сплошное адресное пространство, а как совокупность указателей на различные, не обязательно смежные страницы. Для различных задач могут быть разные таблицы сегментов и разные связи с таблицами страниц. В результате обеспечивается на логическом уровне – сегментная организация, а на физическом – страничная.

# Организация виртуальной памяти в Intel 80386 и более старших моделях.

Эти процессоры могут работать в трех режимах:

1. Реальный режим – работает как быстрый процессор i8086, особенно с 32-битными данными, и имеет адресное пространство памяти до 4Гб.
2. Защищенный режим – использует виртуальную организацию памяти, многозадачную работу, развитую систему защиты памяти (программ и данных).
3. Реализация виртуальной машины i8086 – используется для совместимости с процессором i8086, при этом процессор эффективно реализует программы, написанные для процессора i8086

В защищенном режиме размер виртуальной памяти C ВАП =246б = 64Гб. Это достигается благодаря разбиению ВАП на 16К сегментов, максимальный размер каждого из которых равен 4 Гб.

При организации виртуальной памяти используется три вида адресов.

1. Логический адрес ЛА ∈ ВАП.
2. Физический адрес ФА ∈ ФАП.
3. Линейный адрес – представляет собой объединение базового адреса сегмента и смещения в пределах сегмента.

Любое описание сегмента состоит из двух частей: ***программно-доступной,*** *называемой* ***селектором*** ***сегмента*** и размещаемой в одном из сегментных регистров, ***и скрытой,*** *называемой* ***дескриптором сегмента*** и находящейся в одной из специальных структур в ОП, называемых таблицами дескрипторов. Считается, что дескриптор после выборки размещается в скрытой части регистра сегментов, находящейся в памяти (рис. 6.10).

Доступная (селектор) Скрытая (дескриптор)

15 0 63 0

CS БАС Граница Атрибуты - это дескриптор сегмента

(БАС – базовый адрес сегмента)

DS

GS

Сегментный

регистр Индекс TI RPL (Поля селектора)

Селектор 15 … 3 2 1 0 (Номера битов)

Рис. 6.10

Индекс задает смещение строки с описанием (дескриптором) данного сегмента в таблице дескрипторов.

Поле TI определяет таблицу дескрипторов, на которую ссылается селектор (0 – глобальная, 1 – локальная ).

Поле RPL (0 - 3) - запрашиваемый уровень привелегий (инициатор запроса – программа, которая хочет получить доступ к ресурсам).

Содержание селекторов сегментов формируется операционной системой при загрузке задачи.

*Структура дескриптора сегмента* (рис. 6.11)

31 …24 23 22 21 20 19 … 16 15 14..13 12 11.. 9 8 7 … 0

База G D 0 AVL Граница P DPL S тип А База

База сегмента [0-15] Граница сегмента [0 -15]

Рис 6.11

Основные поля сегмента размещены в различных частях дескриптора: 32-битная база сегмента размещена в трех частях и определяет его место внутри 4-Гбайтного линейного адресного пространства, 20-битная граница сегмента размещена в двух частях и определяет его длину, остальные биты дескриптора образуют поле атрибутов. Длина сегмента, в зависимости от бита дробности (G), задается либо в байтах, либо в страницах: при G=0 – в байтах, а при G= 1 – в страницах (С = 4Кб) и объем будет 220 \* 215 = 232 (4Гб).

Бит D задает тип данных, размещенных в сегменте:

D = 0 – 16-битные данные, D = 1 – 32-битные данные.

AVL – бит, предоставляемый в распоряжение пользователя (available).

Бит P – бит присутствия: 0 – на диске, 1 – в оперативной памяти, биты DPL – уровень привилегий дескриптора (Descriptor Privilege Level), обеспечивающий защиту доступа к сегменту..

При доступе к сегменту запрашиваемый уровень привилегий RPL или текущий уровень привилегий CPL (соответствует уровню привилегий дескриптора кода выполняемой сейчас программы) должны быть больше DPL (в логическом смысле; для сравнения их числовых значений отношение должно быть меньше).

Бит S – бит режима сегмента: пользовательский или системный (User / Supervisor).

Биты типа говорят, является сегмент программой или данными и определяют режим доступа:

|  |  |  |  |
| --- | --- | --- | --- |
| Биты | 11 | 10 | 9 |
| Данные | 1 | E | W |
| Код | 0 | C | R |

R – только чтение; W – только запись; E – бит расширения при загрузке сегмента (1 – при увеличении адресов, 0 – при уменьшении адресов); бит С – признак согласования сегментов (уровень привилегий, с которыми обращается к данному сегменту, всегда приравнивается к уровню данного сегмента – в моделях процессоров выше i386 он существует только для поддержки).

Бит А – бит обращения к сегменту, устанавливается при обращении к сегменту и через некоторое время сбрасывается операционной системой (обеспечивает дисциплины замещения сегментов).

*Алгоритм преобразования виртуального адреса в физический адрес* (рис. 6.12).

База Виртуальный

или

логический

+ Смещение адрес

(ЛА)

+ \* Индекс

Коэффициент

масштабирования (1,2,4,8)

ЛА селектор ЛА смещения

Сегментная трансляция

Линейный адрес

0

PG&PE

1

DIR PAGE offset

Страничная трансляция

Физический адрес ФА

Рис. 6.12

*Схема выполнения сегментной трансляции* (рис. 6.13)

GDT LDT

& Дескриптор & Дескриптор

0

T I 1

Регистр

Индекс TI RPL сегмента База сегмента Граница Атрибуты

15 3 2 1 0 (32) (20) (12)

+ Смещение

Рис.6.13 Линейный адрес (32)

I этап

***Сегментная трансляция*** – это преобразование логического адреса (селектор сегмента и смещение сегмента из команды программы) в линейный адрес. На основании селектора происходит выборка дескриптора из локальной или глобальной таблицы дескрипторов и запись его в скрытую часть сегментного регистра. В результате формируется линейный адрес сегмента (ЛАС) по правилу ЛАС = БАС + смещение.

II этап

***Страничная трансляция*** (Рис.6.14) – это преобразование линейного адреса в физический адрес. Если используется реальный режим или нет разбиения сегмента на страницы, то этот этап пропускается и ФА = ЛАС.

Каталог Страница Смещение Линейный адрес

(10) (10) (12)

PG PE TC1 TC2

CR0

+ + + ФА

dir page

CR3 База адреса каталога

Рис.6.14

CRi – i-й ( i =0..3) регистр управления, PG – бит признака страничной организации сегмента, PE (Protect Enable) – признак установки защищенного режима; (CR0. PG)&(CR0. PE) = 1 - признак страничной трансляции. ТС1 – таблица каталогов, ТС2 – таблица страниц

Размер ФАП = 1К каталогов\* 1К страниц \* 4К смещение = 1k x 1k x 4k= 4Gb.

Формат строки таблицы страниц:

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
| 31 12 | 11 | 10 7 | 6 | 5 | 4 3 | 2 | 1 | 0 |
| Адрес страни-чного кадра | AVL | 0 | D | A | 00 | U/S | R/W | P |

AVL – бит, предоставляемый в распоряжение пользователя, бит P – бит присутствия страницы, бит D – бит мусора, бит А – бит обращения к странице, бит U/S (User / Supervisor) – бит режима использования страницы: пользовательский или системный, бит R/W (Read/Write) – бит доступа (по чтению/записи).

# Защита памяти в процессоре Intel 80386

Обеспечивается только при CR0.PE =1(защищенный режим). Защита может осуществляться на уровне страниц и на уровне сегментов.

Защита на уровне сегментов и на уровне страниц обеспечивается либо по атрибутам дескриптора сегмента, либо по атрибутам строки таблицы страниц. При защите на уровне сегментов влияет соотношение уровней привилегий:

RPL – запрашиваемый уровень (при помещении селектора в сегментный регистр);

DPL – уровень привилегий дескриптора, фиксируется при первом обращении к данным дескриптора и является минимальным уровнем, при котором данный сегмент доступен.

CPL – текущий уровень привилегий, который соответствует уровню кодового сегмента текущей программы.

***Виды защиты на уровне сегментов:***

1. Контроль типа не зависит от уровня привилегий, определяется дескриптором
2. Контроль границ
3. Ограничение адресуемой области памяти.
4. Ограничение точек входа в процедуру зависят от RPL, DPL, CPL
5. Ограничение набора команд.

*Контроль типа выполняется:*

1. На этапе загрузки селектора в регистр сегмента (проверка типа сегмента, для которого осуществляется загрузка селектора)
2. На этапе обращения к сегменту.

Примеры: В CS может быть загружен только селектор дескриптора программного сегмента; в DS не может быть загружен селектор дескриптора, который не доступен для чтения; в SS не может быть загружен селектор дескриптора, который не доступен для записи.

При обращении:

1. Нельзя записать в кодовый сегмент.
2. Нельзя записать в сегмент данных, если бит записи равен нулю.
3. Нельзя читать кодовый сегмент, если бит чтения равен нулю.

*Контроль границ.* Предотвращает выход за пределы сегмента.

*Ограничение адресуемой области памяти.*  Доступ к памяти возможен при условии

{RPL, CPL} ≤ DPL (численно).

*Ограничение точек входа в процедуру*.

Если CPL = DPL, то возможен вход в процедуру по Call, Jump.

Если CPL ≥ DPL (численно), то возможен только доступ по Call через специальный дескриптор, называемый «вентиль вызова».

*Ограничение набора команд.* Все команды по уровню доступа на выполнение делятся на 3 группы:

1. Свободные команды (непривилегированные) – выполняются в любом режиме.
2. Привилегированные команды – выполняются на уровне ядра.
3. Чувствительные команды, зависят от уровня привилегий, но могут выполняться в любом режиме супервизора (от 0 до 2). В основном это команды ввода-вывода.

***Виды защиты на уровне страниц:***

1. Контроль типа.
2. Ограничение адресной области памяти.

*На уровне страниц* защита зависит только от битов режима U/S и доступа R/W.

# *Организация работы с внешней памятью*

## 7.1. Типы, виды, свойства дисковых накопителей информации.

Выпускаемые накопители информации представляют собой гамму запоминающих устройств (ЗУ) с различным принципом действия, физическими и эксплуатационными характеристиками. ЗУ принято делить на виды и категории в связи с их принципами функционирования, эксплуатационными, физическими и программными характеристиками. Так, например, по принципам функционирования различают следующие виды устройств:

* электронные,
* магнитные,
* оптические
* смешанные – магнитооптические.

Каждый тип устройств организован на основе соответствующей технологии хранения/воспроизведения/записи цифровой информации. Рассмотрим дисковые магнитные накопители – накопители на жестких и гибких магнитных дисках (НЖМД и НГМД).

## 7.2. Магнитные дисковые накопители.

Магнитные ЗУ состоят из собственно устройств чтения/записи информации и магнитного носителя, на который осуществляется запись и с которого считывается информация. Общая технология магнитных ЗУ состоит в намагничивании переменным магнитным полем участков носителя при записи информации и считывания информации, закодированной как области переменной намагниченности. Запись производится в цифровом коде. Дисковые устройства делят на два типа:

* гибкие (*Floppy Disk*)
* и жесткие (*Hard Disk*).

Основным свойством дисковых магнитных ЗУ является запись информации на концентрические замкнутые дорожки носителя с использованием физического и логического цифрового кодирования информации. Плоский дисковый носитель вращается в процессе чтения/записи, обеспечивая обслуживание всей концентрической дорожки, чтение и запись осуществляется при помощи магнитных головок чтения/записи, которые позиционируют по радиусу носителя с одной дорожки на другую. Дисковые устройства, как правило, используют метод записи, называемый методом без возвращения к нулю с инверсией (*Not Return Zero – NRZ*). Запись по методу *NRZ* осуществляется путем изменения направления тока в обмотках головок чтения/записи, вызывающее изменение полярности намагниченности магнитных головок и попеременное намагничивание участков носителя вдоль концентрических дорожек с течением времени и продвижением по окружности носителя.

Накопители на ЖМД объединяют в одном корпусе носители и устройство чтения/записи, а также интерфейсную часть, называемую собственно контроллером жесткого диска. Обычно, рядом с корпусом носителей и головок располагаются схемы управления головками, дисками и интерфейсная часть и/или контроллер.

Информация заносится на концентрические дорожки, равномерно распределенные по всему носителю. В случае большего, чем один диск, числа носителей все дорожки, находящиеся одна под другой, называются цилиндром. Операции чтения/записи производятся подряд над всеми дорожками цилиндра, после чего головки перемещаются на новую позицию.

Диски вращаются постоянно, а скорость вращения носителей довольно высокая (от 4500 до 10000 об/мин и выше), что обеспечивает высокую скорость чтения/записи. По величине диаметра носителя чаще других производятся 5.25, 3.14, 2.3 дюймовые диски.

*Позиционирование головок.*

В настоящее время, для позиционирования головок чтения/записи, наиболее часто, применяются шаговые и линейные двигатели механизмов позиционирования и механизмы перемещения головок в целом. В системах с шаговым механизмом и двигателем головки перемещаются на определенную величину, соответствующую расстоянию между дорожками, дискретность шагов зависит либо от характеристик шагового двигателя, либо задается серво-метками на диске. В системах с линейным приводом головки перемещаются электромагнитом, а для определения необходимого положения служат специальные сервисные сигналы, записанные на носитель при его производстве и считываемые при позиционировании головок. Линейные приводы перемещают головки значительно быстрее, чем шаговые, кроме того они обеспечивают положение головки, наилучшее для считывания с каждой дорожки и этим повышают достоверность считываемых данных. Также все устройства с линейным приводом имеют автоматический механизм парковки головок чтения/записи при отключении питания устройства.

*Парковкой головок* называют процесс их перемещения в безопасное положение. Это - так называемое "парковочное" положение головок в той области дисков, где ложатся головки. Там, обычно, не записано никакой информации, кроме серво - это специальная "посадочная зона" (Landing Zone). Для фиксации привода головок в этом положении в большинстве ЖД используется маленький постоянный магнит, когда головки принимают парковочное положение - этот магнит соприкасается с основанием корпуса и удерживает позиционер головок от ненужных колебаний.

*Плата электроники* современного накопителя на ЖМД представляет собой самостоятельный микрокомпьютер с собственным процессором, памятью, устройствами ввода/вывода и прочими традиционными атрибутами присущими компьютеру.

## 7.3. Основные физические и логические параметры ЖМД

Все накопители соответствуют стандартам, определяемым либо независимыми комитетами, либо самими производителями. Среди множества технических характеристик, отличающих одну модель от другой, можно выделить наиболее важные с точки зрения пользователей и производителей, которые используются при сравнении накопителей различных производителей и выборе устройства:

* Диаметр дисков (disk diameter)
* Число поверхностей (sides number)
* Число цилиндров (cylinders number)
* Число секторов (sectors count)
* Число секторов на дорожке (sectors per track)
* Частота вращения шпинделя (spindle speed)
* Время перехода от одной дорожки к другой (track-to-track seek time)
* Среднее время установки или поиска (average seek time)
* Время ожидания (latency)
* Время доступа (access time)
* Среднее время доступа к данным (average access time)
* Скорость передачи данных (data transfer rate)
* Размер кеш-буфера контроллера (internal cash size).
* Средняя потребляемая мощность (capacity).
* Уровень шума (noise level)
* Среднее время наработки на отказ (MTBF)
* Физический и логический объем накопителей.

## 7.4. Контроллеры жестких дисков

Контроллер НЖМД физически расположен на плате электроники и предназначен для обеспечения операций преобразования и пересылке информации от головок чтения/записи к интерфейсу накопителя. Это сложнейшее устройство - микрокомпьютер, со своим процессором, ОЗУ и ПЗУ, схемами и системой ввода/вывода и т.п.. Однако, в большинстве случаев, производители размещают их в одном или двух микрочипах. Многие производители создают устройства, которые записывают различный объем информации на внутренние и внешние дорожки за счет размещения на них разного числа секторов. Это возможно, благодаря аппаратному скрытию от программ и пользователя физических характеристик устройства на уровне его контроллера и/или интерфейса (устройства с IDE, EIDE и SCSI интерфейсами). Поэтому, накопители, как правило, имеют различное физическое и логическое число цилиндров.

Режимы работы контроллеров НЖМД

Большинство современных накопителей поддерживают следующие режимы работы контроллеров:

* PIO
* DMA2
* Ultra DMA.

PIO (Programmed Input/Output - программный ввод/вывод), при котором все пересылки выполняет непосредственно центральный процессор. DMA - Direct Memory Access - прямой доступ к памяти - режим взаимодействия контроллера накопителя и интерфейса ПК, при котором обмен данными осуществляется без участия центрального процессора ПК. Режим DMA позволяет заметно разгрузить процессор по сравнению с режимом PIO. Все современные накопители могут работать в режиме DMA2, если это поддерживается ОС, а скорость обмена при этом может достигать16.6 Мб/с.

Накопители и системы с поддержкой режима Ultra DMA, при использовании соответствующего драйвера, могут передавать и принимать информацию со скоростью 33.3 Мб/с для Ultra DMA-33, 66 Мб/с для Ultra DMA-66 и 100 Мб/с для Ultra DMA-100. В настоящее время все современные модели винчестеров поддерживают стандарты Ultra DMA-66 и Ultra DMA 100.

## Логическое хранение и кодирование информации

Для обеспечения оптимальной производительности НЖМД, а также для улучшения программного интерфейса, в них на основе физически присутствующих структур - дорожек и секторов, используется логическая структура хранения и доступа к информации. Она называется файловой системой, а ее тип и характеристики зависят от используемой ОС. В настоящее время имеется много типов различных файловых систем, но они основывают свои логические структуры данных на нескольких первичных логических структурах. Рассмотрим их подробнее.

*Master Boot Record (MBR)*

Первый сектор жесткого диска содержит хозяйственную загрузочную запись - **Master Boot Record** (MBR), которая, в свою очередь, содержит загрузочную запись - Boot Record (BR), выполняющуюся в процессе загрузки ОС. Загрузочная запись жестких дисков является объектом атаки компьютерных вирусов, заражающих MBR. За загрузчиком расположена таблица разделов - Partition Table (PT), содержащая 4 записи - элементы логических разделов - Partitions. Завершается MBR специальной сигнатурой - последовательностью из 2-х байт с шестнадцатиричными значениями 55H и ААH, указывающая на то, что данный раздел, после которого расположена сигнатура, является последним разделом в таблице.

Структура MBR.

|  |  |
| --- | --- |
| Название записи в MBR | Длина, байт |
| Загрузочная запись – Boot Record | 446 |
| Элемент таблицы разделов 1 – Partition 1 | 16 |
| Элемент таблицы разделов 2 – Partition 2 | 16 |
| Элемент таблицы разделов 3 – Partition 3 | 16 |
| Элемент таблицы разделов 4 – Partition 4 | 16 |
| Сигнатура окончания Partition Table | 2 |

Каждый элемент таблицы разделов содержит информацию о логическом разделе. Первым байтом в элементе раздела идет флаг активности раздела (0 - не активен, 128 (80H) - активен). Он служит для определения, является ли раздел системным и можно ли производить с него загрузку ОС при старте компьютера. Активным может быть только один раздел. Небольшие программы, называемые менеджерами загрузки (Boot Manager), могут располагаться в первых секторах диска. Они интерактивно запрашивают пользователя, с какого раздела производить загрузку, и соответственно корректируют флаги активности разделов. За флагом активности раздела следует байт номера головки, с которой начинается раздел. За ним следует два байта, означающие соответственно номер сектора и номер цилиндра загрузочного сектора, где располагается первый сектор загрузчика ОС. Загрузчик ОС представляет собой маленькую программу, осуществляющую считывание в память начального кода ОС во время ее старта. Затем следует байт – кодовый идентификатор ОС, расположенной в разделе, за ним расположен байт номера головки конца раздела, за которым идут два байта – номер сектора и номер цилиндра последнего сектора раздела.

*Формат таблицы разделов*

| **Название записи элемента Partition Table** | **Длина, байт** |
| --- | --- |
| Флаг а**к**тивности раздела | 1 |
| Номер головки начала раздела | 1 |
| Номер сектора и номер цилиндра загрузочного сектора раздела | 2 |
| Кодовый идентификатор операционной системы | 1 |
| Номер головки конца раздела | 1 |
| Номер сектора и цилиндра последнего сектора раздела | 2 |
| Младшее и старшее двухбайтовое слово относительного номера начального сектора | 4 |
| Младшее и старшее двухбайтовое слово размера раздела в секторах | 4 |

Завершают элемент раздела младшее и старшее двухбайтовое слово относительного номера первого сектора раздела и размер раздела в секторах соответственно.

Номера сектора и номер цилиндра секторов в разделах занимают 6 и 10 бит соответственно. Ниже представлен формат записи, содержащей номера сектора и цилиндра.

Биты номера цилиндра Биты номера сектора

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

Для жестких дисков типичной является ситуация, когда имеется четыре записи в таблице разделов и соответственно четыре раздела. ОС MS-DOS использует только два из них, остальные резервируются для параллельного использования других ОС. Благодаря наличию такой структуры как MBR, на одном физическом жестком носителе может располагаться несколько файловых систем различного типа различных операционных систем. Структуры MBR представляют собой важную информацию, повреждение которой приводит к частичной или полной потере доступа к данным логических устройств жесткого диска и к невозможности загрузки ОС с поврежденного носителя.

***Логические разделы.***

Логические разделы тоже имеют иерархическую структуру в зависимости от типа ОС и ее файловой системы.

Так, первый раздел жесткого диска в MS-DOS называется главным разделом (**Primary Partition**), а второй расширенным (**Extended Partition**). Главный раздел всегда должен присутствовать на диске, с него происходит загрузка MS-DOS. Расширенного раздела может не быть, он создается лишь в случае, когда необходимо получить более одного логического устройства на физическом диске. Логический раздел размещает в себе такие структуры файловой системы как логические диски, устройства или тома (оформленные как подразделы), загрузчик операционной системы, таблицы распределения файлов, области пользовательских данных в которых размещаются записи о каталогах и файлах и данные файлов. Число логических подразделов может быть более четырех, а последний элемент каждого показывает, является ли он последним логическим подразделом раздела.

Основной единицей хранения информации в MS-DOS и других ОС с похожей логической структурой разделов является кластер (cluster) - группа секторов. В таких ОС для распределения минимального дискового пространства в один байт выделяется целый кластер, содержащий много секторов и еще больше байт (килобайты), что приводит к нерациональному использованию пространства ЖД для мелких файлов. Для доступа к каждому кластеру создается таблица соответствия номеров кластеров файлам логического раздела - таблица распределения файлов (File Allocation Table - FAT). Поэтому, файловые систем такого типа называют FAT-системы. Это не самый оптимальный, но довольно быстрый способ организации информации на разделах, поэтому он "дожил" до наших дней с давних времен начала развития ПК, где использовался исключительно для накопителей на гибких магнитных дисков. Все остальные логические структуры - файлы или каталоги связаны локализацией с FAT.

Для других ОС, например, UNIX - использование разделов происходит иначе. Как правило, их может быть более четырех, все они равноправны и одинаково могут быть загрузочными, содержат собственные файловые системы на основе i-узлов. Такие файловые системы являются теговыми и не имеют таблиц распределения порций информации. Дисковое пространство распределяется посекторно, что дает максимально возможное использование пространства раздела, но несколько снижает производительность. Весь раздел разбивается на иерархически связанную цепочку узлов разного уровня, которым соответствует некоторое количество секторов. На основе узлов строится понятие файлов и каталогов, и в таких системах файлы и каталоги действительно не различаются, т.к. каталог является файлом, содержащим структуру узлов. Один раздел отводится для дискового свопа и имеет упрощенную структуру, т.к. никогда не содержит файлов и каталогов.

Все разделы могут содержать **загрузчик операционной системы**, который располагается, как правило, в первом секторе и занимает один сектор. В этом секторе располагаются структуры - записи, имеющие отношение лишь к конкретной ОС и следовательно они могут отличаться для разных разделов и версий ОС. Многие специализированные программы (например, защиты данных, по борьбе и профилактике вирусов и др.) могут изменять структуру или отдельные части загрузчика операционных систем. Загрузчик большинства персональных однопользовательских операционных систем является объектом заражения вирусами, которые заражают загрузочные сектора жестких дисков.

## Интерфейсы жестких дисков

Интерфейсом накопителей называется набор электроники, обеспечивающий обмен информацией между контроллером устройства (кеш-буфером) и компьютером. В настоящее время в настольных ПК, чаще других, используются две разновидности интерфейсов ATAPI - AT Attachment Packet Interface (Integrated Drive Electronics - IDE, Enhanced Integrated Drive Electronics - EIDE) и SCSI (Small Computers System Interface).

*Интерфейс IDE*

Разрабатывался как недорогая и производительная альтернатива высокоскоростным интерфейсам ESDI и SCSI. Интерфейс, предназначен для подключения двух дисковых устройств. Отличительной особенностью дисковых устройств, работающих с интерфейсом IDE состоит в том, что собственно контроллер НЖМД располагается на плате самого накопителя вместе со встроенным внутренним кэш-буфером. Такая конструкция существенно упрощает устройство интерфейсной карты и дает возможность размещать ее не только на отдельной плате адаптера, вставляемой в разъем системной шины, но и интегрировать непосредственно на материнской плате компьютера. Интерфейс характеризуется простотой, высоким быстродействием, малыми размерами и относительной дешевизной.

Сегодня на смену интерфейсу IDE пришло детище фирмы Western Digital - Enhanced IDE, или сокращенно EIDE. Сейчас это лучший вариант для подавляющего большинства настольных систем. Жесткие диски EIDE заметно дешевле аналогичных по емкости SCSI-дисков (см. ниже) и в однопользовательских системах не уступают им по производительности, а большинство материнских плат имеют интегрированный двухканальный контроллер для подключения четырех устройств.

Можно выделить шесть основных отличий расширенного стандарта:

1. большая емкость дисков; если IDE не поддерживал диски свыше 528 мегабайт, то EIDE преодолевает это ограничение;
2. к нему подключается больше устройств - четыре вместо двух. Вместо одного канала контроллера для подключения двух IDE устройств используются два: основной - на высокоскоростной локальной шине и вспомогательный;
3. появилась спецификация ATAPI, дающая возможность подключения к этому интерфейсу не только жестких дисков, но и других устройств - стриммеров и дисководов CD-ROM;
4. повысилась производительность: НЖМД с интерфейсом IDE имели максимальную скорость передачи данных на уровне 3 мегабайт в секунду, а диски EIDE поддерживают несколько новых режимов обмена, которые обеспечивают скорость передачи данных 11.1 и 16.6 мегабайт в секунду соответственно.
5. поддерживается режим прямого доступа к памяти - Multiword Mode 1 DMA (Direct Memory Access) или Multiword Mode 2 DMA и Ultra DMA, которые поддерживают обмен данными в монопольном режиме, при котором канал ввода-вывода в течение некоторого времени обслуживает только одно устройство;
6. расширена система команд управления устройством, передачи данных и диагностики, увеличен кеш-буфер обмена данными и существенно доработана механика.

*Интеллектуальный многофункциональный интерфейс SCSI*

Был разработан в конце 70-х годов в качестве устройства сопряжения компьютера и интеллектуального контроллера дискового накопителя. Интерфейс SCSI является универсальным и определяет обмен данными между центральным процессором и несколькими внешними устройствами, имеющими свой контроллер. Помимо электрических и физических параметров, определяются также команды, при помощи которых, устройства, подключенные к шине, осуществляют связь между собой. Интерфейс SCSI поддерживает значительно более широкую гамму периферийных устройств и стандартизован ANSI (X3.131-1986).

Сегодня применяются в основном три стандарта:

* SCSI-2
* Ultra SCSI.
* SCSI-3

В режиме Fast SCSI-2 скорость передачи данных доходит до 10 мегабайт в секунду при использовании 8-разрядной шины и до 20 мегабайт при 16-разрядной шине Fast Wide SCSI-2.

Появившийся позднее стандарт Ultra SCSI отличается еще большей производительностью - 20 мегабайт в секунду для

8-разрядной шины и 40 мегабайт для 16-разрядной.

В новейшем SCSI-3 увеличен набор команд, но быстродействие осталось на том же уровне.

Все применяющиеся сегодня стандарты совместимы с предыдущими версиями "сверху - вниз", то есть к адаптерам SCSI-2 и Ultra SCSI можно подключить старые SCSI-устройства. Интерфейс SCSI-Wide, SCSI-2, SCSI-3 - стандарты модификации интерфейса SCSI, разработаны комитетом ANSI. Общая концепция усовершенствований направлена на увеличение ширины шины до 32-х, с увеличением длины соединительного кабеля и максимальной скорости передачи данных с сохранением совместимости с SCSI. Это наиболее гибкий и стандартизованный тип интерфейсов, применяющийся для подключения 7 и более периферийных устройств, снабженных контроллером интерфейса SCSI. Интерфейс SCSI остается достаточно дорогим и самым высокопроизводительным из семейства интерфейсов периферийных устройств персональных компьютеров.

## Работа накопителя

Теперь рассмотрим процесс работы накопителя от запуска до остановки. При подаче питающих напряжений начинает работать микропроцессор контроллера. Вначале он, как и компьютер, выполняет самотестирование и в случае его успеха запускает схему управления двигателем вращения шпинделя. Диски начинают раскручиваться, увлекая за собой прилегающие к поверхностям слои воздуха, и при достижении некоторой скорости давление набегающего на головки потока воздуха преодолевает силу пружин, прижимающих их к дискам, и головки "всплывают", поднимаясь над дисками на доли микрона. С этого момента, вплоть до остановки дисков, головки не касаются дисков, поэтому ни диски, ни сами головки практически не изнашиваются. Двигатель шпинделя продолжает раскручивать поверхности и его скорость приближается к номинальной (тысячи оборотов в минуту). В это время накопитель потребляет максимум питающего напряжения 12 вольт. Поскольку в любой зоне дисков присутствует серворазметка, то сервоимпульсы начинают поступать с головок сразу же после начала вращения, и по их частоте контроллер судит о скорости вращения дисков. После достижения шпинделем номинальной скорости вращения освобождается фиксатор позиционера головок чтения/записи, и система его управления проверяет способность поворачиваться и удерживаться на выбранной дорожке путем выборочного произвольного позиционирования. При этом делается серия быстрых поворотов в разные стороны, что на слух выглядит как характерное "тарахтение", слышимое через несколько секунд после старта. Во время перемещения позиционера головок происходит слежение за поступающими с головок серво-импульсами, и система управления всегда "знает", над сколькими дорожками прошли головки. Аналогично происходит и удержание головок над выбранной дорожкой - при отклонении от центра дорожки изменяется во времени величина и форма серво-импульсов. Система управления может ликвидировать отклонение, изменяя ток в обмотках двигателя позиционера головок.

Микрокомпьютер НЖМД имеет ПЗУ, в котором записана BIOS накопителя - набор программ для начального запуска и управления во время работы, и ОЗУ, в которое после раскрутки механической системы загружаются остальные части управляющих программ. Также в ОЗУ загружается так называемая карта переназначения дефектных секторов, в которой отмечены дефектные секторы, выявленные при заводской разметке дисков. Эти секторы исключаются из работы и иногда подменяются резервными, которые имеются на каждой дорожке или в специальных резервных зонах каждого диска. На каждом диске имеется некоторый запас резервных секторов, которыми можно подменить и появляющиеся впоследствии дефекты либо под управлением специальных программ, либо автоматически в процессе работы.

После начальной настройки электроники и механики микрокомпьютер ЖД переходит в режим ожидания команд контроллера, расположенного на системной плате или интерфейсной карте, который в свою очередь программируется процедурами собственной BIOS или BIOS компьютера под управлением ОС. Получив команду, он позиционирует на нужный цилиндр, по сервоимпульсам отыскивает нужную дорожку, дожидается, пока до головки дойдет нужный сектор, и выполняет считывание или запись информации. Если контроллер запросил чтение/запись не одного сектора, а нескольких - накопитель может работать в блочном режиме, используя ОЗУ в качестве буфера и совмещая чтение/запись нескольких секторов с передачей информации к контроллеру или от него.

При выключении питания двигатель шпинделя работает в режиме генератора, обеспечивая питание плат электроники на время, необходимое для корректного завершения работы. Прежде всего, блокируется подача тока записи в магнитные головки, чтобы они не испортили информацию на поверхностях, а остаток энергии подается в обмотки привода головок, толкая их к центру дисков для автопарковки. Любой исправный накопитель всегда запаркует головки, как бы внезапно не было выключено питание, но если в этот момент происходила запись информации, то последствия могут быть плохими из-за недописанных областей данных или управляющих структур файловой системы ПК, независимо от типа и вида установленной ОС.

## Внешняя память на CD и DVD дисках.

*Устройство CD-диска*

Стандартный компакт-диск (CD) состоит из трех слоев:

* основы,
* отражающего
* и защитного.

Основа выполнена из прозрачного поликарбоната, на котором методом прессования сформирован информационный рельеф. Поверх рельефа напыляется металлический отражающий слой (алюминий, золото, серебро, другие металлы и сплавы). Отражающий слой покрывается сверху защитным слоем поликарбоната или нейтрального лака - так, чтобы вся металлическая поверхность была защищена от контакта с внешней средой.

Информационный рельеф диска представляет собой непрерывную спиральную дорожку, начинающуюся от центра и состоящую из последовательности углублений - питов (pits). Промежутки между питами носят название lands. Чередованием питов и промежутков различной длины на диске записывается закодированный цифровой сигнал: переход от промежутка к питу и наоборот обозначает единицу, а длина пита или промежутка - длину серии нулей. Расстояние между витками дорожки выбирается от 1.4 до 2 мкм, стандарт определяет расстояние в 1.6 мкм.

*Представление звукового сигнала*

Исходный стереофонический звуковой сигнал подвергается оцифровке в 16-разрядные отсчеты (квантование) с частотой дискретизации 44.1 кГц. В начале диска располагается вводная зона, содержащая информацию о формате диска, структуре звуковых программ, адресах фрагментов, названиях произведений и т.п. В конце записывается выводная зона (дорожка с номером AA), выполняющая роль границы записанной области диска.

Общая длительность записи на компакт-диске - 74 минуты. Записи состоят из фреймов, по 588 отстчетов для левого и для правового каналов. В каждой секунде звукозаписи содержится по 75 фреймов соответственно. Можно перемножить 588\*75=44100.

*Способы записи и изготовления*

Основной способ изготовления дисков - прессование с матрицы. Оригинал формируется с исходной цифровой мастер-ленты, содержащей уже подготовленный и закодированный цифровой сигнал, специальным высокоточным станком на стеклянном диске, покрытом слоем фоторезиста - материала, изменяющего свою растворимость под воздействием лазерного луча. При обработке записанного оригинала растворителем на стекле возникает требуемый рельеф, который методом гальванопластики переносится на никелевый оригинал (негатив), который может служить матрицей при мелкосерийном производстве, либо основой для снятия позитивных копий, с которых, в свою очередь, снимаются негативы для массового тиражирования. Штамповка выполняется методом литья под давлением: с негативной матрицы прессуется поликарбонатная подложка с рельефом, сверху напыляется отражающий слой, который покрывается лаком.

*Воспроизведение звука*

При воспроизведении звуковой компакт-диск вращается с постоянной линейной скоростью относительно воспроизводящей головки (приблизительно 1.25 м/с). Система стабилизации скорости вращения обеспечивает скорость считан-ного цифрового потока равной 4.3218 Мбит/с, поэтому в зависимости от длины питов и промежутков действительная скорость может изменяться. Угловая скорость диска при этом изменяется от 500 об/мин при чтении самых внутренних участков дорожки до 200 об/м на самых внешних.

Для считывания информации с диска используется полупроводниковый лазер с длиной волны около 780 нм (инфракрасный диапазон). Луч лазера, проходя через фокусирующую линзу, падает на отражающий слой, отраженный луч попадает в фотоприемник, где происходит определение питов и промежутков, а также проверка качества фокусировки пятна на дорожке и его ориентации по центру дорожки.

*CD-R и CD-RW*

Система однократной (CD-Recordable - записываемый CD) и многократной (CD-ReWritable - перезаписываемый CD) записи компакт-дисков. Терминами CD-R, CD-E и CD-RW обозначаются как устройства для записи, так и сами диски.

Для однократной записи используются так называемые "болванки", представляющие собой обычный компакт-диск, в котором отражающий слой выполнен преимущественно из золотой или серебряной пленки, а между ним и поликарбонатной основой расположен регистрирующий слой из органического материала, темнеющего при нагревании. В процессе записи лазерный луч нагревает выбранные точки слоя, которые темнеют и перестают пропускать свет к отражающему слою.

В перезаписываемых дисках используется промежуточный слой из органической пленки, изменяющей под воздействием луча свое фазовое состояние с аморфного на кристаллическое и обратно, в результате чего меняется прозрачность слоя. Фиксация изменений состояния происходит благодаря тому, что материал регистрирующего слоя при нагреве свыше критической температуры переходит в аморфное состояние и остается в нем после остывания, а при охлаждении до температуры значительно ниже критической восстанавливает кристаллическое состояние. Существующие диски выдерживают от тысяч до десятков тысяч циклов перезаписи. Однако их отражающая спосо-бность существенно ниже штампованных и однократных CD, что затрудняет их считывание в обычных приводах. Для чтения CD-RW формально необходим привод с автоматической регулировкой усиления фотоприемника

Запись дисков CD-R выполняется при помощи специальных программ - Easy CD, CD Creator, CD Publisher, Direct CD и т.п. Процесс записи одной дорожки представляет собой единую операцию, которая не может быть прервана, иначе диск будет испорчен. Для обеспечения равномерности поступления записываемой информации на лазер все приводы имеют буфер, исчерпание данных в котором приводит к аварийному прерыванию записи.

*Приводы CD-ROM*

Типовой привод состоит из:

* платы электроники,
* шпиндельного двигателя,
* системы оптической считывающей головки
* и системы загрузки диска.

На плате электроники размещены все управляющие схемы привода, интерфейс с контроллером компьютера, разъемы интерфейса и выхода звукового сигнала.

Шпиндельный двигатель служит для приведения диска во вращение с постоянной или переменной линейной скоростью.

Система оптической головки состоит из самой головки и системы ее перемещения. В головке размещены лазерный излучатель, на основе инфракрасного лазерного светодиода, система фокусировки, фотоприемник и предварительный усилитель. Изменение напряженности магнитного поля вызывает перемещение линзы и пеpефокусиpовку лазерного луча. Система перемещения головки имеет собственный приводной двигатель, приводящий в движение каретку с оптической головкой.

Система загрузки диска выполняется в двух вариантах: с использованием специального футляра для диска, вставляемого в приемное отверстие привода, и с использованием выдвижного лотка, на который кладется сам диск.

При стандартной скорости вращения скорость передачи данных составляет около 150 Кб/с. В двух- и более скоростных CD-ROM диск вращается с пропорционально большей скоростью, и пропорционально повышается скорость передачи, например, 1200 Кб/с для 8-скоpостного диска.

В настоящее время типичные скорости 40-50.

*Интерфейсы приводов CD-ROM*

В настоящее время CD-ROM выпускаются только с интерфейсами SCSI и IDE. Диски подключается непосредственно к магистрали SCSI или IDE (ATA) с заданием номеpа устройства для SCSI или Master/Slave - для IDE.

*DVD*

Первоначально сокращение DVD расшифровывалось как digital video disc - оптические диски с большой емкостью. Эти диски используются для хранения компьютерных программ и приложений, а так же полнометражных фильмов и высококачественного звука. Появившаяся позже расшифровка аббревиатуры DVD, как digital versatile disc, т.е. универсальный цифровой диск - более логична.

Хотя DVD выглядят как обычные диски CD-ROM, они могут хранить в 26 раз больше данных. Однослойный, односторонний диск DVD может хранить 4.7GB данных, двухслойный, односторонний - до 8.5GB, двухсторонний - до 17GB.

Как и CD-ROM, диски DVD хранят данные за счет насечек , расположенных вдоль спиральных треков на отражающей металлической поверхности, покрытой пластиком. Используемый в устройствах чтения DVD дисков лазер скользит вдоль треков по насечкам, а отраженный луч интерпретируется приемным устройством в виде единиц или нулей. Благодаря разработке более высокочастотного полупроводникового лазера с меньшей длиной волны, стало возможным использовать насечки меньшего размера.

Другие новшества:

* новый формат секторов,
* более надежный код коррекции ошибок
* улучшенная модуляция каналов.

Все эти улучшения увеличивают плотность записи данных в полтора раза. Жесткие производственные требования и незначительно большая поверхность записи стали препятствием при разработке DVD, ограничивающим емкость размещаемых на диске данных до 4.7Gb. Для записи видео и звука на DVD применяется компрессии данных, носящая название MPEG-2 и MPEG-4. Это увеличивает временную емкость записываемых данных.

## Принципы организации RAID массивов

***Назначение.***

В переводе с английского “RAID” (Redundant Array of Independent Disks) означает “избыточный массив независимых дисков”. Впервые термин RAID появился в 1987 году, когда исследователям из Калифорнийского Университета в Беркли удалось создать массив из нескольких жестких дисков.

Предназначение RAID - создание на базе нескольких жестких дисков сравнительно небольшой емкости одного логического диска c:

* большой емкостью;
* увеличенной скоростью доступа;
* увеличенной надежностью хранения;
* возможностью восстановления данных в случае отказа части оборудования.

Именно эти обстоятельства сделали RAID-массивы столь востребованными бизнесом и военными. Впрочем, за объем, скорость и надежность пришлось платить повышением стоимости и сложности систем хранения данных. Со временем оборудование для построения RAID массивов стало более доступным, особенно с появлением дешевых решений для IDE/ATA и SATA дисков.

Впрочем, найти оптимальное решение одновременно по надежности, скорости, емкости и цене дисковой памяти не просто. Надо быть готовым к тому, что придется купить не один, а несколько жестких дисков, и емкость как минимум одного из них не будет использоваться. Кроме того, потребуется специальный корпус с отдельным или двумя блоками питания, платой контроллера и соответствующее программное обеспечение.

## Основные принципы построения RAID массивов

В основе теории RAID лежат пять основных принципов:

* массив (Array);
* зеркалирование (Mirroring) или дублирование;
* чередование полос (Striping);
* контроль четности (Parity).

***Массивом*** называют несколько накопителей, которые централизованно настраиваются, форматируются и управляются. Логический массив – это уже более высокий уровень представления, на котором не учитываются физические характеристики системы. Соответственно, логические диски могут по количеству не совпадать с физическими. Но лучше все-таки соблюдать соответствие: физический диск – логический диск. Наконец, для операционной системы вообще весь массив является одним большим логическим диском.

***Зеркалирование*** – технология, позволяющая повысить надежность системы. В RAID массиве с зеркалированием все данные одновременно пишутся не на один, а на два жестких диска. То есть создается «зеркало» данных. При выходе из строя одного из дисков вся информация остается сохраненной на втором.

За такую стопроцентную защиту приходится дорого платить: считайте, что один винчестер у вас работает просто так, не увеличивая доступную емкость ни на Мегабайт. При этом нет никакого выигрыша в производительности. Столь дорогое решение используется только во внешних RAID-массивах, предназначенных для ответственных приложений.

***Чередование полос*** – отличная возможность повысить быстродействие системы. Очевидно, если чтение и запись вести параллельно на нескольких жестких дисках, можно получить выигрыш в скорости. Как это делается? Записываемый файл разбивается на части определенного размера (полосы - strip) и одновременно размещается на всех имеющихся накопителях в последовательном порядке. В таком фрагментированном виде файл и хранится. Считывание и запись соседних полос выполняется параллельно с разных дисков.

Размер «кусочка» может быть минимальным – 1 байт, но чаще используют более крупное дробление – по 512 байт (размер сектора).

***Контроль четности***  является альтернативным решением, соединяющим в себе достоинства зеркалирования (высокая надежность) и чередования (высокая скорость работы).

Используется тот же принцип, что и в контроле четности оперативной памяти. Если имеется i блоков данных и на их основе вычисляется еще один дополнительный экстраблок, из получившихся (i+1) блоков всегда можно восстановить информацию даже при повреждении одного из них. Соответственно, для создания нормального RAID-массива в этом случае требуется (i+1) жесткий диск.

Распределение блоков по дискам точно такое же, как при чередовании. Экстраблок может записываться на отдельный накопитель, либо раскидываться по дискам.

Что же хранится в экстраблоке? Каждый бит экстраблока равен результату выполнения логической операции XOR над соответствующими битами всех i блоков. Многие помнят со школы, что XOR – удивительный оператор, при его повторном наложении мы можем получить первоначальный результат. То есть (A XOR B) XOR B = A. Это правило распространяется на любое количество операндов.

Плюсы четности очевидны. За счет использования чередования повышается скорость работы. Повышение надежности за счет зеркалирования здесь делается так, что при этом «нерабочий» объем массива заметно уменьшается, он одинаков при любом количестве дисков и составляет емкость одного диска, то есть при 5 дисках в массиве пропадает всего 20% емкости.

Но у четности есть весомый минус. Для формирования экстраблоков требуются вычисления! Их надо делать на лету, причем с миллионами бит! Если это дело поручить центральному процессору, мы получим очень медленную систему. Необходимо использовать довольно дорогие платы с RAID-контроллерами, которые «берут все вычисления на себя». В случае выхода из строя одного из дисков, процесс восстановления будет не столь быстрым, как при зеркалировании.

## Одиночные уровни RAID

Исследователи из Беркли в 1988 году придумали такую классификацию, не учитывая, что обычно уровни четко связаны с иерархией. В RAID уровнях нет преемственности. RAID 4 не есть улучшенная модификация RAID 3, так же как RAID 5 не лучше RAID 1. Просто они разные. Следует отметить, что есть простые (single) и составные (multiple) RAID массивы. Составные являются сочетанием двух простых. Сначала рассмотрим простые 7 уровней.

***RAID 0***

![raid0+](data:image/png;base64,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)

Структура RAID 0

Простейший массив, использующий чередование полос без четности. Вся входящая информация разбивается на блоки фиксированной длины (например, 16 кбайт) и раскидывается на все имеющиеся диски.

При наличии двух-четырех дисков RAID 0 дает ощутимый выигрыш в скорости передачи данных, но совершенно не обеспечивает надежность. Для его построения подойдет любой дешевый и даже программный RAID-контроллер. Подходит для тех, кому нужно выжать максимум производительности от файловой системы при минимальных затратах.

***RAID 1***

![raid1+](data:image/png;base64,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)

Структура RAID 1

Этот уровень является обычным зеркалированием. На два жестких диска пишутся две одинаковые копии данных. При этом можно использовать дешевый RAID контроллер или даже его программную реализацию. RAID 1 позволяет надежно защитить данные и обеспечить работу системы даже при поломке одного из дисков. Вот почему он получил широкое распространение среди пользователей, желающих защитить от потери личные данные. Выигрыша в скорости при использовании RAID1 нет.

***RAID 2***

![raid2+](data:image/png;base64,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)

Структура RAID 2

Второй уровень RAID умер, так и не родившись. Исследователи из Беркли предложили использовать одновременно две технологии – побитовое чередование и код Хэмминга для восстановления ошибок. В теории это должен быть неплохой по надежности и рабочей емкости массив, построенный из 14 или 39 дисков (!). При этом часть дисков (10 или 32) используется для хранения данных с чередованием, остальные – для хранения вычисленных контрольных сумм. Реализация таких систем требовала специальных дорогостоящих контроллеров, которые так и не прижились на рынке. В итоге RAID 2 сейчас не используется.

***RAID 3***

![raid3+](data:image/png;base64,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)

Структура RAID 3

Третий уровень использует чередование полос и выделенный диск для контроля четности. Блоки данных обычно имеют длину меньше 1024 байт. Информация распределяется на несколько дисков, а вычисленные значение контроля по четности сохраняются на отдельном диске.

Все скоростные преимущества чередования сводятся на нет необходимостью записывать контрольную сумму на выделенный диск, а больше всех страдает скорость случайной записи. К достоинствам следует отнести возможность работы массива при отказе одного из дисков.

***RAID 4***

![raid4+](data:image/png;base64,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)

Структура RAID 4

Отличается от RAID 3 только размером блока данных при чередовании (значительно больше – не менее 2-х физических блоков диска). Это несколько улучшает работу массива при случайном чтении, но запись все равно довольно медленная. Диск с контрольными суммами является ярко выраженным «узким местом» в системе.

RAID 4 является компромиссным вариантом между RAID 3 и RAID 5, не нашел своего места на рынке и редко используется. Это держит цены на соответствующие контроллеры на высоком уровне.

***RAID 5***

![raid5+](data:image/png;base64,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)

Структура RAID 5

Наиболее распространенный в системах хранения данных – пятый уровень. Он характеризуется применением чередования полос и контроля четности. В отличие от RAID 3, контрольные суммы не хранятся на одном диске, а распределяются по всем, что позволяет значительно поднять скорость записи. Главный принцип распределения экстраблоков - они не должны располагаться на том же диске, который учитывался привычислении паритета.

Надежность и скорость работы такой системы оказываются очень высокими. При восстановлении информации всю работу на себя берет RAID контроллер, так что операция проходит довольно быстро.

***RAID 6***

Для некоторых особо критичных приложений требуется повышенная надежность. Например, чтобы при выходе из строя даже двух дисков массив сохранил данные и остался работоспособным. Это обеспечивается на уровне RAID 6. При этом используются все те же технологии чередования полос и контроля четности, но в отличие от RAID 5 контрольная сумма вычисляется два раза и копируется на два разных диска. В итоге данные окажутся потерянными только в случае выхода из строя сразу двух жестких дисков. По сравнению с RAID 5 это более дорогое и медленное решение: увеличивается время на вычисление запись паритетной информации требуется дополнительное дисковое пространство. На практике RAID 6 почти не используется, так как выход из строя сразу двух дисков – слишком редкий случай, а повысить надежность можно другими способами.

## Составные уровни RAID массивов

У основных уровней RAID есть свои достоинства и недостатки. И вполне понятно, почему инженеры стали мечтать о таком RAID, который бы объединял достоинства нескольких уровней. Составной RAID массив – это чаще всего сочетание быстрого RAID 0 с надежным RAID 1, 3 или 5. Итоговый массив действительно обладает улучшенными характеристиками, но и платить за это приходится повышением стоимости и сложностью решения.

Составной RAID строится так: сначала диски разделяются на наборы (set). Затем на основе каждого из наборов строятся простые массивы. А завершается все объединением этих массивов в один мегамассив. Запись типа X+Y означает, что сначала диски объединены в RAID уровня X, а затем несколько RAID X массивов объединены в RAID уровня Y.

***RAID 0+1 (01) и 1+0 (10)***

RAID 0+1 часто называют «зеркалом страйпов», а RAID 1+0 – «страйпом зеркал» (нормальное русское «чередование» практически не используется, сменившись англоязычным). В обоих случаях используются две технологии – чередование и зеркалирование, но результаты разные.

![raid01](data:image/png;base64,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)

Структура RAID 0 + 1

RAID 0+1 обладает высокой скоростью работы и повышенной надежностью, поддерживается даже дешевыми RAID контроллерами и является недорогим решением. Но по надежности несколько лучше RAID 1+0. Так, массив из 10 дисков (5 по 2) может остаться работоспособным при отказе до 5 жестких дисков! Основной недостаток массивов 1+0 – низкий процент использования емкости накопителей – всего 50%. Но для домашних систем именно RAID 01 или 10 может оказаться оптимальным решением.

![raid10](data:image/png;base64,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)

Структура RAID 1 + 0

***RAID 0+3 (03) и 3+0 (30)***

По идее сочетание чередования и RAID 3 дает выигрыш в скорости, но он довольно мал. Зато система заметно усложняется. Наиболее простой уровень 3+0. Из двух массивов RAID 3 строится страйп, и минимальное количество требуемых дисков – 6. Получившийся RAID 3+0 с точки зрения надежности лучше, чем 0+3.

Достоинства этих комбинаций в довольно высоком проценте использования емкости дисков и высокой скорости чтения данных. Недостатки – высокая цена, сложность системы.

***RAID 0+5 (05) и 5+0 (50)***

Что будет, если объединить чередование с распределенной четностью с обыкновенным чередованием ? Получится быстрая и надежная система. RAID 0+5 представляет собой набор страйпов, на основе которых построен RAID 5. Такая комбинация используется редко, так как практически не дает выигрыша ни в чем. Широкое распространение получил составной RAID массив 5+0.

Чаще всего это два массива RAID 5, объединенных в страйп. Такая конфигурация позволяет получить высокую производительность при работе с файлами малого размера. Типичный пример – использование в качестве WEB-сервера.

![raid50](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAcIAAAFPCAMAAADp6D5xAAADAFBMVEX//////8z//5n//2b//zP//wD/zP//zMz/zJn/zGb/zDP/zAD/mf//mcz/mZn/mWb/mTP/mQD/Zv//Zsz/Zpn/Zmb/ZjP/ZgD/M///M8z/M5n/M2b/MzP/MwD/AP//AMz/AJn/AGb/ADP/AADM///M/8zM/5nM/2bM/zPM/wDMzP/MzMzMzJnMzGbMzDPMzADMmf/MmczMmZnMmWbMmTPMmQDMZv/MZszMZpnMZmbMZjPMZgDMM//MM8zMM5nMM2bMMzPMMwDMAP/MAMzMAJnMAGbMADPMAACZ//+Z/8yZ/5mZ/2aZ/zOZ/wCZzP+ZzMyZzJmZzGaZzDOZzACZmf+ZmcyZmZmZmWaZmTOZmQCZZv+ZZsyZZpmZZmaZZjOZZgCZM/+ZM8yZM5mZM2aZMzOZMwCZAP+ZAMyZAJmZAGaZADOZAABm//9m/8xm/5lm/2Zm/zNm/wBmzP9mzMxmzJlmzGZmzDNmzABmmf9mmcxmmZlmmWZmmTNmmQBmZv9mZsxmZplmZmZmZjNmZgBmM/9mM8xmM5lmM2ZmMzNmMwBmAP9mAMxmAJlmAGZmADNmAAAz//8z/8wz/5kz/2Yz/zMz/wAzzP8zzMwzzJkzzGYzzDMzzAAzmf8zmcwzmZkzmWYzmTMzmQAzZv8zZswzZpkzZmYzZjMzZgAzM/8zM8wzM5kzM2YzMzMzMwAzAP8zAMwzAJkzAGYzADMzAAAA//8A/8wA/5kA/2YA/zMA/wAAzP8AzMwAzJkAzGYAzDMAzAAAmf8AmcwAmZkAmWYAmTMAmQAAZv8AZswAZpkAZmYAZjMAZgAAM/8AM8wAM5kAM2YAMzMAMwAAAP8AAMwAAJkAAGYAADMAAADNzc0AfwBPTk9Y4+Qdhoaz//+r5OTX///h///p///v///1//8AewAWiRZ5u3mp1KkiIyL7/fv+//79/v33+Pfn6Oe+3r3///7y8vHs3t7//f3+/v79/f36+vr5+fn19fXs7Ozg4ODY2NjExMS5ubmsrKyBgYH///+2AaegAAABAHRSTlP///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////8AU/cHJQAAAAFiS0dEAIgFHUgAAAAMY21QUEpDbXAwNzEyAAAAA0gAc7wAADGASURBVHhe7X27etvIsi4eRitCtp5CmR0hmzeYzN9K7JMgW28wmbcSR6ez/QY78+dEOwIMWyZ1sd2yBC3M0YW4f+evxq0BAiQAARQJozVDUyLY6Oof1XXp6ipFmds8A/MMzDMwz8A8A/MMzDMwz8A8A/MMDDgDK89vaM6Ad5m7GnEGNIPVNyMe8a5z1wPOQKw3dKY1fTDgzeeuhpiBRqQasR3irnMfA86AjFTIwqLnmQsHnOVRu5KQcixDK+41c+Go8z5g5wVSj2EsQzhz4YCzPGpXBVJeFM5cOOpcj9R5wYVWrBuWm99m5sKRZnzwbgukYt0ymJffYJaFg8/1SB2WNNJZFo40y6N2K6+XTlCso8rMhaPO+4Cdz96ZASfzZbqavTMvM+8D3nXmwgEn82W6mrnwZeZ9wLvOXDjgZL5MV9G8X/gyEz/cXWPdrd21d2ejYrhJHrenRqRmCMed+OF6z9WZG+rz5tfsIx1ubnfUU85s109hbCsCSNFmLtwRAs++TWFURNxiftHfvFPx7LndUQcFs3lmaKjFXWcu3BECz76NxGw+l+MOZy589tzuqAOZ2TQuLaQzF+4IgWffpmA2HwupFP40c+Gz53ZHHRTMpnFLd2ZZuKN5H/A2hV14H2mOcj/bhQNO7m66mr0zu5nnEe/SKPJmWTjirA/a9cyFg07nS3Q2c+FLzPqg99SYFtc1jc3nCwed6PE603is1/7MEI436cP2PMvCYefzBXqbZeELTPqwtyz2C3859sP1vF847PTuoreCC0PG48I5o8x24S6mf4h7FLIwjkMjmn2kQ0zqbvuQmS2SIZy5cLdA9L9bIQsVk+tF9NMcO9N/Tnf8zYLZbB470s1nLtwxEr1vJ+0XxrbzMMvC3jP5Yl8smI0xLm/5zlz4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)

Структура RAID 5 + 0

***RAID 1+5 (15) и 5+1 (51)***

Этот уровень построен на сочетании зеркалирования и чередования с распределенной четностью. Основная цель RAID 15 и 51 – значительное повышение надежности. Массив 1+5 продолжает работать при отказе трех накопителей, а 5+1 - даже при потере пяти из восьми жестких дисков! Платить приходится большим количеством неиспользуемой емкости дисков и общим удорожанием системы.

Чаще всего для построения RAID 5+1 используют два контроллера RAID 5, которые зеркалируют на программном уровне, что позволяет снизить затраты.

# *Сравнительные результаты*

*Распространенные single RAID массивы*

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
|  | **RAID 0** | **RAID 1** | **RAID 3** | **RAID 5** | **RAID 6** |
| **Технология** | Чередование | Зеркали- рование | Чередование, четность | Чередование, четность | Чередование, четность |
| **Контроллер** | Все | Все | Аппаратный | Аппаратный Hi-End | Специали- зированный |
| **Кол-во жест. диск.** | 2, 4 | 2 | 3 и больше | 3 и больше | 3 и больше |
| **Доступное рабочее пространство, %** | 100 | 50 | 66 для 3, 75 для 4 | 66 для 3, 75 для 4 | 33 для 3 50 для 4 60 для 5 |
| **Стойкость при отказе диска** | Нет | Высокая | Высокая | Высокая | Очень высокая |
| **Восстановление данных** | Нет | Быстрое | Быстрое | Быстрое | Очень быстрое |
| **Скорость случайного чтения** | Высокая | Хорошая | Хорошая | Очень хорошая | Очень хорошая |
| **Скорость случайной записи** | Высокая | Хорошая | Плохая | Нормальная | Плохая |
| **Скорость линейного чтения** | Высокая | Хорошая | Очень хорошая | Очень хорошая | Хорошая |
| **Скорость линейной записи** | Высокая | Хорошая | Хорошая | Хорошая | Средняя |
| **Цена** | Самая низкая | Низкая | Средняя | Средняя | Высокая |

*Распространенные multi-RAID массивы*

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
|  | **RAID 0+1** | **RAID 1+0** | **RAID 5+0** | **RAID 5+1** |
| **Технология** | Чередование, зеркалирование | Чередование, зеркалирование | Чередование, четность | Чередование, четность, зеркалирование |
| **Контроллер** | Почти все | Почти все | Специали- зированный | Специали- зированный |
| **Кол-во жест. диск** | 4 min | 4 min | 6 min | 6 min |
| **Доступное рабочее пространство, %** | 50 | 50 | 66 для 2 страй-пов по 3 диска | 33-40 |
| **Стойкость при отказе диска** | Оч. хорошая | Отличная | Хорошая | Отличная |
| **Восстановление данных** | Быстрое | Очень быстрое | Среднее | Быстрое |
| **Скорость случайного чтения** | Очень хорошая | Очень хорошая | Очень хорошая | Очень хорошая |
| **Скорость случайной записи** | Хорошая | Хорошая | Хорошая | Хорошая |
| **Скорость линейного чтения** | Очень хорошая | Очень хорошая | Очень хорошая | Очень хорошая |
| **Скорость линейной записи** | Хорошая | Хорошая | Хорошая | Хорошая |
| **Цена** | Относительно высокая | Относительно высокая | Высокая | Очень высокая |

# Системные и локальные шины

# 9.1. Общие положения и требования к шинам

При работе компьютера, состоящего из множества подсистем, необходим механизм для их взаимодействия. Эти подсистемы должны быстро и эффективно обмениваться данными. Например, процессор, с одной стороны, должен быть связан с памятью; с другой стороны, необходима связь памяти и процессора с устройствами ввода/вывода. Связь между различными подсистемами компьютера обеспечивается с помощью наборов линий, называемых шинами. Шины можно разделить на группы в соответствии с выполняемыми ими функциями. Шины могут быть внутренними по отношению к процессору и служить для передачи данных между АЛУ и регистрами, а могут быть внешними по отношению к процессору и связывать процессор с памятью или устройствами ввода/вывода.

Операции на шине назавыются **транзакциями**. Основные виды – транзакции чтения и транзакции записи или транзакции ввода и транзакции вывода. Шинная транзакция состоит из двух частей: посылка адреса и прием (или посылка) данных.

Связанные с шиной устройства должны подчиняться определённым правилам, которые называют протоколами шины. Некоторые устройства, связанные с шиной, являются активными и могут инициировать передачу информации по шине, а другие – пассивными и ждут запросов. Активное устройство называют задающим (bus master), пассивное – подчинённым (bus slave). Процессор является задающим устройством, если он требует от контроллера считать или записать информацию. В этом случае контроллер является пассивным устройством. Контроллер становится задающим устройством, если он командует приёмом слов в память, ранее считанных им с диска.

Механизм, обеспечивающий как связь, так и взаимодействие устройств компьютера, реализуется с помощью унифицированной совокупности средств связи – интерфейсов, которые требуют стандартизации, распространяемой на форматы передаваемых данных, команды, наборы шин, алгоритмы, сигналы и т. д. Интерфейс – это совокупность унифицированных шин для передачи информации, электрических схем, управляющих прохождением сигналов по шинам и алгоритмов, управляющих обменом информации.

Интерфейсы подразделяют на односвязные и многосвязные. Односвязные интерфейсы используют единственную центральную шину – магистраль, к которой подсоединяются все устройства на основе принципа разделения времени. Так как несколько устройств могут одновременно стать ведущими и пытаться захватить шину, то магистраль должна использоваться в режиме разделения времени. Ведущие устройства снабжаются приоритетом использования магистрали.

Подобная организация имеет два основных преимущества:

* низкая стоимость,
* универсальность.

Поскольку такая шина является единственным местом подсоединения для разных устройств, новые устройства могут быть легко добавлены в систему. Стоимость такой организации получается достаточно низкой, поскольку для реализации множества путей передачи информации используется единственный набор линий шины, разделяемый множеством устройств. Главным недостатком организации с единственной шиной является то, что **шина создает узкое место**, ограничивая максимальную пропускную способность ввода/вывода.

В коммерческих системах, где ввод/вывод осуществляется очень часто, а также в суперкомпьютерах, где необходимые скорости ввода/вывода очень высоки из-за высокой производительности процессора, одним из главных вопросов связи устройств является создание системы нескольких шин, способной удовлетворить все запросы. Использование для связи устройств в компьютере нескольких независимых систем шин характерно для многосвязных интерфейсов.

Для всех видов передачи информации используется стандартная совокупность сигналов и общие временные диаграммы. Так как устройства имеют разные характеристики по быстродействию, то они подключаются к шинам через соответствующие контроллеры. Характеристики интерфейса со стороны периферийного устройства должны быть согласованы с характеристиками этого устройства. В соответствии с типом устройства надо использовать специализированный интерфейсный кристалл, на котором реализованы аппаратные средства интерфейса. Поскольку внешние сигналы периферийных устройств могут отличаться, то для унификации интерфейсного кристалла эти отличия реализуются программным путем. Такой интерфейс принято называть программируемым. Отличия определяются с помощью записи значений соответствующих битовых комбинаций в предусмотренные для этого регистры интерфейсного кристалла.

## 9.2. Основные виды, характеристики и параметры шин

Одна из причин трудностей, возникающих при разработке шин, заключается в том, что максимальная скорость шины главным образом лимитируется физическими факторами:

* длиной шины,
* количеством подсоединяемых устройств.

Эти физические ограничения не позволяют произвольно ускорять шины. Требования малой задержки, высокой пропускной способности и подключения разных устройств являются противоречивыми. В современных крупных системах используется целый комплекс взаимосвязанных шин, каждая из которых обеспечивает упрощение взаимодействия различных подсистем, высокую пропускную способность, избыточность (для увеличения отказоустойчивости) и эффективность.

Традиционно шины делятся:

* на шины, обеспечивающие организацию связи процессора с памятью,
* шины ввода/вывода.

Шины ввода/вывода могут иметь большую протяженность, поддерживать подсоединение многих типов устройств и обычно следуют одному из шинных стандартов.

Шины процессор–память, с другой стороны, сравнительно короткие, обычно высокоскоростные и соответствуют организации системы памяти для обеспечения максимальной пропускной способности канала память–процессор. На этапе разработки системы для шины процессор–память заранее известны все типы и параметры устройств, которые должны соединяться между собой, в то время как разработчик шины ввода/вывода должен иметь дело с устройствами, различающимися по задержке и пропускной способности.

Как уже было отмечено, с целью снижения стоимости некоторые компьютеры имеют единственную шину для памяти и устройств ввода/вывода. Такая шина часто называется системной. Персональные компьютеры, как правило, строятся на основе одной системной шины в стандартах ISA или PCI. Необходимость сохранения баланса производительности по мере роста быстродействия микропроцессоров привела к двухуровневой организации шин в персональных компьютерах на основе системной и локальной шин. Локальной шиной называется шина, электрически выходящая непосредственно на контакты микропроцессора. Она обычно объединяет процессор, память, схемы буферизации для системной шины и ее контроллер, а также некоторые вспомогательные схемы. Типичным примером локальной шины является VL-Bus.

Разработка системы шин связана с обеспечением ряда функциональных возможностей, характеризующихся определенными параметрами (табл. 9.1).

Таблица 9.1

| **Возможность** | **Высокая**  **производительность** | **Низкая стоимость** |
| --- | --- | --- |
| Общая разрядность шины | Отдельные линии  адреса и данных | Мультиплексирование  линий адреса и данных |
| Ширина (разрядность)  данных | Чем шире, тем быстрее  (например, 32 бит) | Чем уже, тем дешевле  (например, 8 бит) |
| Размер пересылки | Пересылка нескольких слов имеет меньшие накладные расходы | Пересылка одного слова дешевле |
| Режим и способ  передачи данных | Дуплексный,  параллельный | Симплексный, полудуплекс-  ный, последовательный |
| Главные устройства  шины | Несколько  (требуется арбитраж) | Одно  (арбитраж не нужен) |
| Наличие расщепленных  транзакции? | Да – отдельные пакеты Запроса и Ответа дают большую полосу пропускания (но нужно несколько главных устройств) | Нет – продолжающееся соединение дешевле и имеет меньшую задержку |
| Тип синхронизации | Синхронные | Асинхронные |

Решение о выборе той или иной возможности зависит от целевых параметров стоимости и производительности. Первые три возможности являются очевидными:

* раздельные линии адреса и данных,
* более широкие (имеющие большую разрядность) шины данных,
* режим групповых пересылок (пересылки нескольких слов).

Они дают увеличение производительности за счет увеличения стоимости. Далее на скорость работы шины оказывают влияние режим и способ передачи данных. Существуют следующие режимы передачи данных: симплексный, полудуплексный и полнодуплексный (или просто дуплексный) и способы передачи: параллельный и последовательный.

При симплексном режиме данные передаются только в одном направлении. Используя транспортную аналогию, симплексную передачу можно представить как однонаправленную однополосную дорогу. Сейчас она редко используется па практике.

Полудуплексный режим является самым распространенным. Он похож на однополосную дорогу, по которой движение может осуществляться в обоих направлениях, но не одновременно, а последовательно.

Режим полного дуплекса похож на двухполосную, двунаправленную дорогу. Данные могут передаваться в обоих направлениях одновременно.

Параллельная передача характеризуется тем, что группа битов передается одновременно по нескольким проводникам. Каждый бит передается по собственному проводу. Например, все внутренние коммуникации компьютера с его устройствами осуществляются через параллельную передачу. Это быстрый способ передачи. Однако при больших расстояниях он становится экономически невыгодным не только из-за того, что требует значительно больше кабеля, но и по причине взаимных помех этих проводников.

При последовательной передаче группа битов передается последовательно, один за другим по одному проводнику. Она медленнее, но экономически более выгодна при передаче на большие расстояния.

Также важной характеристикой шины является количество ее главных (задающих) устройств (bus master). Главное устройство шины – это устройство, которое может инициировать транзакцию (передачу) записи или чтения. ЦП, например, всегда является главным устройством шины. Шина может иметь несколько главных устройств, если имеется несколько ЦП или когда устройства ввода/вывода могут инициировать транзакции на шине. Если вналичии несколько таких устройств, то требуется схема арбитража, чтобы решить, кто следующий захватит шину. Арбитраж часто основан либо на схеме с фиксированным приоритетом, либо на более «справедливой» схеме, которая случайным образом выбирает, какое главное устройство захватит шину.

В настоящее время используются два типа шин, отличающиеся способом коммутации:

* шины с коммутацией цепей (circuit-switched bus),
* шины с коммутацией пакетов (packet-switched bus).

Они получили свои названия по аналогии со способами коммутации в сетях передачи данных.

Шина с коммутацией пакетов при наличии нескольких главных устройств шины обеспечивает значительно большую пропускную способность по сравнению с шиной с коммутацией цепей за счет разделения транзакции (передачи) на две логические части: запроса шины и ответа. Такая методика получила название «расщепления» транзакций (split transaction). Транзакция чтения разбивается на транзакцию запроса чтения, которая содержит адрес, и транзакцию ответа памяти, которая содержит данные. Каждая транзакция теперь должна быть помечена (тегирована) соответствующим образом, чтобы ЦП и память могли сообщить, что есть что.

Шина с коммутацией цепей не делает расщепления транзакций, любая транзакция на ней есть неделимая операция. Главное устройство запрашивает шину, после арбитража помещает на нее адрес и блокирует шину до окончания обслуживания запроса. Большая часть этого времени обслуживания при этом тратится не на выполнение операций на шине (например, на задержку выборки из памяти). Таким образом, в шинах с коммутацией цепей это время просто теряется. Расщепленные транзакции делают шину доступной для других главных устройств, пока память читает слово по запрошенному адресу. Это, правда, также означает, что ЦП должен бороться за шину для посылки данных, а память должна бороться за шину, чтобы вернуть данные. Таким образом, шина с расщеплением транзакций имеет более высокую пропускную способность, но обычно она имеет и большую задержку, чем шина, которая захватывается на все время выполнения транзакции. Транзакция называется расщепленной, поскольку произвольное количество других пакетов или транзакций могут использовать шину между запросом и ответом.

Последний вопрос связан с выбором типа синхронизации и определяет, является ли шина синхронной или асинхронной. Если шина синхронная, то она включает сигналы синхронизации, которые передаются по линиям управления шины, и фиксированный протокол, определяющий расположение сигналов адреса и данных относительно сигналов синхронизации. Поскольку практически никакой дополнительной логики не требуется для того, чтобы решить, что делать в следующий момент времени, эти шины могут быть и быстрыми, и дешевыми. Однако они имеют два главных недостатка. Все на шине должно происходить с одной и той же частотой синхронизации, поэтому из-за проблемы перекоса синхросигналов синхронные шины не могут быть длинными. Обычно шины процессор–память синхронные.

Асинхронная шина, с другой стороны, не тактируется. Вместо этого обычно используется старт-стопный режим передачи и протокол «рукопожатия» (handshaking) между источником и приемником данных на шине. Данные передаются как последовательность нулей и единиц, поэтому приемник должен уметь выделять байт в этом потоке данных. При асинхронной передаче каждый байт обрамляется стартовым и стоповым битом, с помощью которых приемник может их разделить. Эта схема позволяет гораздо проще приспособить широкое разнообразие устройств и удлинить шину без беспокойства о перекосе сигналов синхронизации и о системе синхронизации. В целом асинхронная передача является относительно недорогой, потому что не требует дорогостоящего оборудования.

Если может использоваться синхронная шина, то она обычно быстрее, чем асинхронная, из-за отсутствия накладных расходов на синхронизацию шины для каждой транзакции. Выбор типа шины (синхронной или асинхронной) определяет не только пропускную способность, но также непосредственно влияет на емкость системы ввода/вывода в терминах физического расстояния и количества устройств, которые могут быть подсоединены к шине. Асинхронные шины по мере изменения технологии лучше масштабируются. Шины ввода/вывода обычно асинхронные.

# 9.3. Стандарты шин

Обычно количество и типы устройств ввода/вывода в вычислительных системах не фиксируются, что позволяет пользователю самому подобрать необходимую конфигурацию. Шина ввода/вывода компьютера может рассматриваться как шина расширения, обеспечивающая постепенное наращивание устройств ввода/вывода. Поэтому стандарты играют огромную роль, позволяя разработчикам компьютеров и устройств ввода/вывода работать независимо. Появление стандартов определяется разными обстоятельствами.

Иногда широкое распространение и популярность конкретных машин становятся причиной того, что их шина ввода/вывода становится стандартом де-факто. Примерами таких шин могут служить PDP-11 Unibus и IBM PC-AT Bus. Иногда стандарты появляются в результате определенных достижений по стандартизации в некотором секторе рынка устройств ввода/вывода. Интеллектуальный периферийный интерфейс (IPI – Intelligent Peripheral Interface) и Ethernet являются примерами стандартов, появившихся в результате кооперации производителей. Успех того или иного стандарта в значительной степени определяется его принятием такими организациями, как ANSI (Национальный институт по стандартизации США) или IEEE (Институт инженеров по электротехнике и радиоэлектронике). Иногда стандарт шины может быть прямо разработан одним из комитетов по стандартизации: примером такого стандарта шины является FutureBus.

В табл. 9.2 представлены характеристики нескольких стандартных шин.

Таблица 9.2.

| **Параметр** | **VME bus** | **FutureBus** | **Multibus II** | **IPI** | **SCSI** |
| --- | --- | --- | --- | --- | --- |
| Ширина шины  (количество сигналов) | 128 | 96 | 96 | 16 | 8 |
| Мультиплексирование  адреса/данных | Нет | Да | Да | Да | Да |
| Разрядность данных | 16/32 бит | 32 бит | бит 32 | 16 бит | бит |
| Количество главных  устройств шины | Несколько | Несколько | Несколько | Одно | Несколько |
| Максимальная  полоса пропускания | 27.9 Мб/c | 95.2 Мб/c | 40.0 Мб/c | 25.0 Мб/c | 5.0 Мб/c |
| Максимальное  количество устройств | 21 | 20 | 21 | 8 | 7 |
| Максимальная длина шины | 0.5 м | 0.5 м | 0.5 м | 50 м | 25 м |

*Системная шина IBM PC/XT*

Одной из популярных шин персональных компьютеров была системная шина IBM PC/XT, обеспечивавшая передачу 8 бит данных. Кроме того, эта шина включала 20 адресных линий, которые ограничивали адресное пространство пределом в 1 Мбайт. Для работы с внешними устройствами в этой шине были предусмотрены также 4 линии аппаратных прерываний (IRQ) и 4 линии для требования внешними устройствами прямого доступа к памяти (DMA). Для подключения плат расширения использовались специальные 62-контактные разъемы. При этом системная шина и микропроцессор синхронизировались от одного тактового генератора с частотой 4.77 МГц. Теоретическая скорость передачи данных могла достигать немногим более 4 Мбайт/с.

*Системная шина VME*

Шина VME приобрела большую популярность как шина ввода/вывода в рабочих станциях и серверах на базе RISC-процессоров. Эта шина высоко стандартизована, имеется несколько версий этого стандарта. В частности, VME32 – 32-битовая шина с производительностью 30 Мбайт/с, а VME64 – 64-битовая шина с производительностью 160 Мбайт/с.

*Шина ввода/вывода SCSI*

Одной из наиболее популярных шин ввода-вывода является шина SCSI. Под термином SCSI –Small Computer System Interface (Интерфейс малых вычислительных систем) обычно понимается набор стандартов, разработанных Национальным институтом стандартов США (ANSI) и определяющих механизм реализации магистрали передачи данных между системной шиной компьютера и периферийными устройствами. На сегодняшний день приняты два стандарта (SCSI-1 и SCSI-2). Стандарт SCSI-3 находится в процессе доработки.

Начальный стандарт 1986 г., известный теперь под названием SCSI-1, определял рабочие спецификации протокола шины, набор команд и электрические параметры. В 1992 г. этот стандарт был пересмотрен с целью устранения недостатков первоначальной спецификации (особенно в части синхронного режима передачи данных) и добавления новых возможностей повышения производительности, таких, как «быстрый режим» (fast mode), «широкий режим» (wide mode) и помеченные очереди. Этот пересмотренный стандарт получил название SCSI-2 и в настоящее время используется большинством поставщиков вычислительных систем.

Первоначально SCSI предназначался для использования в небольших дешевых системах и поэтому был ориентирован на достижение хороших результатов при низкой стоимости. Характерной его чертой является простота, особенно в части обеспечения гибкости конфигурирования периферийных устройств без изменения организации основного процессора. Главной особенностью подсистемы SCSI является размещение в периферийном оборудовании интеллектуального контроллера.

Для достижения требуемого высокого уровня независимости от типов периферийных устройств в операционной системе основной машины, устройства SCSI представляются имеющими очень простую архитектуру. Например, геометрия дискового накопителя представляется в виде линейной последовательности одинаковых блоков, хотя в действительности любой диск имеет более сложную многомерную геометрию, содержащую поверхности, цилиндры, дорожки, характеристики плотности, таблицу дефектных блоков и множество других деталей. В этом случае само устройство или его контроллер несут ответственность за преобразование упрощенной SCSI-модели в данные для реального устройства.

Стандарт SCSI-2 определяет, в частности, различные режимы: Wide SCSI, Fast SCSI и Fast-and-Wide SCSI. Стандарт SCSI-1 определяет построение периферийной шины на основе 50-жильного экранированного кабеля, описывает методы адресации и электрические характеристики сигналов. Шина данных SCSI-1 имеет разрядность 8 бит, а максимальная скорость передачи составляет 5 Мбайт/с. Fast SCSI сохраняет 8-битовую шину данных и тем самым может использовать те же самые физические кабели, что и SCSI-1. Он отличается только тем, что допускает передачи со скоростью 10 Мбайт/с в синхронном режиме. Wide SCSI удваивает либо учетверяет разрядность шины данных (либо 16, либо 32 бит), допуская соответственно передачи со скоростью либо 10, либо 20 Мбайт/с. В комбинации Fast-and-Wide SCSI возможно достижение скоростей передачи 20 и 40 Мбайт/сек соответственно. Однако поскольку в обычном 50-жильном кабеле просто не хватает жил, комитет SCSI решил расширить спецификацию вторым 66-жильным кабелем (так называемый B-кабель). B-кабель имеет дополнительные линии данных и ряд других сигнальных линий, позволяющих реализовать режим Fast-and-Wide.

*Системные шины ISA и EISA*

Системная шина *ISA (Industry Standard Architecture)* впервые стала применяться в персональных компьютерах IBM PC/AT на базе процессора i286. Эта системная шина отличалась наличием второго, 36-контактного дополнительного разъема для соответствующих плат расширения. За счет этого количество адресных линий было увеличено на 4, а данных – на 8, что позволило передавать параллельно 16 бит данных и обращаться к 16 Мбайт системной памяти. Количество линий аппаратных прерываний в этой шине было увеличено до 15, а каналов прямого доступа – до 7. Системная шина ISA полностью включала в себя возможности старой 8-разрядной шины. Шина ISA позволяет синхронизировать работу процессора и шины с разными тактовыми частотами. Она работает на частоте 8 МГц, что соответствует максимальной скорости передачи 16 Мбайт/с.

С появлением процессоров i386, i486 и Pentium шина ISA стала узким местом персональных компьютеров на их основе. Новая системная шина *EISA (Extended Industry Standard Architecture),* появившаяся в конце 1988 г., обеспечивает адресное пространство в 4 Гбайт, 32-битовую передачу данных (в том числе и в режиме DMA), улучшенную систему прерываний и арбитраж DMA, автоматическую конфигурацию системы и плат расширения. Устройства шины ISA могут работать на шине EISA. Шина EISA предусматривает централизованное управление доступом к шине за счет наличия специального устройства – арбитра шины. Поэтому к ней может подключаться несколько главных устройств шины. Улучшенная система прерываний позволяет подключать к каждой физической линии запроса на прерывание несколько устройств, что снимает проблему количества линий прерывания. Шина EISA тактируется частотой около 8 МГц и имеет максимальную теоретическую скорость передачи данных 33 Мбайт/с.

В настоящее время широко не используется, вытеснена шиной PCI.

*Системная шина PCI*

Первая версия шины PCI (Peripheral Component Interconnect) поддерживает 32-битовый канал передачи данных между процессором и периферийными устройствами, работает на тактовой частоте 33 МГц и имеет пропускную способность 120 Мбайт/с. Важной чертой шины является ее процессорная независимость. Ee легко подключить к различным ЦП: Pentium, Alpha, R4400 и PowerPC. В связи с переходом на 64-разрядный канал данных, она вытеснила шины стандарта EISA с рынка ПК. Хотя обычно для связи устройств компьютера для эффективного соотношения стоимость/производительность используется несколько типов шин. Пример организации компьютера фирмы Intel с несколькими типами шин показан на рис. 9.1.

Шина Локальная Шина

Кэш- шина памяти

Кэш

память

второго

уровня

Мост

PCI

Процессор

Основная память

SCSI

USB

Мост

ISA

Диск IDE

Графический адаптер

Монитор

Принтер

Звуковая карта

Клавиатура

памяти

Свободное

гнездо PCI

Шина PCI

Шина ISA

Модем

Свободное

гнездо ISA

Рис. 9.1

Центральный процессор, память и шина PCI связаны при помощи моста PCI. Процессор обменивается с памятью по локальной шине процессора и специальной шине памяти. Шина ISA, образующая интерфейс расширения для низкоскоростных устройств, связана с шиной PCI при помощи мостов. Так, мост ISA связывает шину PCI с шиной ISA и поддерживает диск IDE. Имеется свободное гнездо PCI для подключения дополнительных высокоскоростных периферийных устройств и свободное гнездо ISA для дополнительного подключения низкоскоростных периферийных устройств.

Разработка шины PCI началась весной 1991 г. как внутренний проект корпорации Intel. Специалисты компании поставили перед собой цель разработать недорогое решение, которое бы позволило полностью реализовать возможности нового поколения процессоров 486/Pentium/P6. В результате шина PCI появилась в июне 1992 г. (Release 1.0). Разработчики Intel отказались от использования шины процессора и ввели еще одну «антресольную» (mezzanine) шину.

Благодаря такому решению шина получилась, во-первых, процессорно-независимой (в отличие от VLbus), а во-вторых, могла работать параллельно с шиной процессора, не обращаясь к ней за запросами. Например, процессор работает с кэшем или с системной памятью, а в это время по сети на винчестер пишется информация. На самом деле не все получается так идеально, но загрузка шины процессора сильно снижается. Кроме того, стандарт шины был объявлен открытым и передан PCI Special Interest Group, которая продолжила работу по совершенствованию шины (в настоящее время доступен R2.1).

*Основные возможности шины PCI следующие:*

* Синхронный 32- или 64- разрядный обмен данными. При этом для уменьшения числа контактов (и стоимости) используется мультиплексирование, т. е. адрес и данные передаются по одним и тем же линиям.
* Поддержка 5V и 3.3V логики. Разъемы для 5 и 3.3V плат различаются расположением ключей; существуют и универсальные платы, поддерживающие оба напряжения; заметим, что частота 66 MHz поддерживается только 3.3V логикой.
* Частота работы шины 33 MHz или 66 MHz (в версии 2.1) позволяет обеспечить широкий диапазон пропускных способностей (с использованием пакетного режима): 32 МВ/с при 32-bit/33 MHz; 264 MB/с при 32-bit/66 MHz; 264 MB/с при 64-bit/ 33MHz; 528 МВ/с при 64-bit/ 66MHz.

При этом для работы шины на частоте 66MHz необходимо, чтобы все периферийные устройства работали на этой частоте.

* Полная поддержка multiply bus master (например, несколько контроллеров жестких дисков могут одновременно работать на шине).
* Поддержка write-back и write-through кэша.
* Автоматическое конфигурирование карт расширения при включении питания.
* Спецификация шины позволяет комбинировать до восьми функций на одной карте (например, видео + звук и т.д.).
* Шина позволяет устанавливать до 4 слотов расширения, однако возможно использование моста PCI-PCI для увеличения количества карт расширения.
* PCI-устройства оборудованы таймером, который используется для определения максимального промежутка времени, в течение которого устройство может занимать шину.

При разработке шины в ее архитектуру были заложены передовые технические решения, позволяющие повысить пропускную способность:

Шина поддерживает метод передачи данных, называемый «linear burst» (метод линейных пакетов). Этот метод предполагает, что пакет информации считывается (или записывается) «одним куском», т. е. адрес автоматически увеличивается для следующего байта. Естественным образом при этом увеличивается скорость передачи собственно данных за счет уменьшения числа передаваемых адресов.

*Шина AGP*

Эта шина имеет следующие существенные отличия от шины PCI:

* шина способна передавать два блока данных за один 66 MHz цикл (AGP 2x);
* устранена мультиплексированность линий адреса и данных (напомню, что в PCI для удешевления конструкции адрес и данные передавались по одним и тем же линиям);
* дальнейшая конвейеризация операций чтения/записи, по мнению разработчиков, позволяет устранить влияние задержек в модулях памяти на скорость выполнения этих операций.

В результате пропускная способность шины была оценена в 500 МВ/с, и предназначена она для того, чтобы видеокарты хранили текстуры в системной памяти, соответственно имели меньше памяти на плате, и, соответственно, дешевели. Парадокс в том, что видеокарты все-таки предпочитают иметь БОЛЬШЕ памяти, и ПОЧТИ НИКТО не хранит текстуры в системной памяти, поскольку текстур такого объема пока практически нет. При этом в силу удешевления памяти вообще карты особенно и не дорожают.

Шина имеет два основных режима работы: Execute и DMA. В режиме DMA основной памятью является память карты. Текстуры хранятся в системной памяти, но перед использованием (тот самый execute) копируются в локальную память карты. Таким образом, AGP действует в качестве «тыловой структуры», обеспечивающей своевременную «доставку патронов» (текстур) на передний край (в локальную память). Обмен ведется большими последовательными пакетами. В режиме Execute локальная и системная память для видеокарты логически равноправны. Текстуры не копируются в локальную память, а выбираются непосредственно из системной. Таким образом, приходится выбирать из памяти относительно малые случайно расположенные куски. Поскольку системная память выделяется динамически, блоками по 4 К, в этом режиме для обеспечения приемлемого быстродействия необходимо предусмотреть механизм, отображающий последовательные адреса на реальные адреса 4 килобайтных блоков в системной памяти. Эта нелегкая задача выполняется с использованием специальной таблицы (Graphic Address Re-mapping Table или GART), расположенной в памяти.

При этом адреса, не попадающие в диапазон GART (GART range), не изменяются и непосредственно отображаются на системную память или область памяти устройства (device specific range). На рис. 5 в качестве такой области показан локальный фрейм-буфер карты (Local Frame Buffer или LFB). Точный вид и функционирование GART не определены и зависят от управляющей логики карты.

Шина AGP полностью поддерживает операции шины PCI, поэтому AGP-траффик может представлять собой смесь чередующихся AGP и PCI операций чтения/записи. Операции шины AGP являются раздельными (split). Это означает, что запрос на проведение операции отделен от собственно пересылки данных.

Такой подход позволяет AGP-устройству генерировать очередь запросов, не дожидаясь завершения текущей операции, что также повышает быстродействие шины.

В 1998 г. спецификация шины AGP получила дальнейшее развитие – вышел Revision 2.0. В результате использования новых низковольтных электрических спецификаций появилась возможность осуществлять 4 транзакции (пересылки блока данных) за один 66-мегагерцовый такт (AGP 4x), что означает пропускную способность шины в 1GB/с.

Однако потребности и запросы в области обработки видеосигналов все возрастают, и Intel готовит новую спецификацию – AGP Pro (в настоящее время доступен Revision 0.9), направленную на удовлетворение потребностей высокопроизводительных графических станций. Новый стандарт не видоизменяет шину AGP. Основное направление – увеличение энергоснабжения графических карт. С этой целью в разъем AGP Pro добавлены новые линии питания.

# Организация системы ввода-вывода в ВМ

# 10.1. Назначение и основные требования к системе ввода-вывода ВМ

***Назначение системы ввода-вывода*** – это обеспечение взаимодействия центральной части машины с внешней средой (пользователи, устройства, процессы), которое реализуется периферийными (или внешними) устройствами (ПУ или ВУ).

Связь процессора с периферийными устройствами осуществляется:

1. Через аккумулятор (регистр общего назначения).
2. Через оперативную память.

Оперативная память может непосредственно взаимодействовать с внешним устройством (ВУ) в режиме прямого доступа в память (ПДП).

***Основные проблемы ввода-вывода.***

1. Существует большое количество ВУ с различными параметрами, существенно отличающимися:
2. По скорости передачи данных.
3. Формату передачи данных (устройства последовательного, параллельного представления информации и т.д.).
4. Размерам передаваемых данных (биты, байты, слова, блоки, секторы).
5. Количеству выполняемых функций (чтение, запись, перемотка, подсчет, измерение).
6. Различные скорости работы центральной части машины и ВУ (требуется многоуровневая буферная память).
7. Асинхронность работы центральной части машины и ВУ (согласование операций в устройствах).

***Требования к системе ввода-вывода***

1. Гарантировать эффективное согласование центральной части машины и ВУ с целью достижения максимальной производительности.
2. Обеспечение распределения ВУ между одновременно выполняемыми задачами в системе (большинство машин работают в многозадачных режимах).
3. Обеспечение управления каждым конкретным внешним устройством.
4. Обеспечение дружественного интерфейса с пользователем.

# 10.2. Архитектура систем ввода-вывода

Существует два основных способа организации системы ввода вывода.

1. Прямой ввод-вывод (рис. 10.1).
2. Косвенный (канальный) ввод-вывод (рис.10.2).

1 ОП

Системная шина

ЦП

2

ОП Контроллер ВУ Контроллер ВУ

ВУ ВУ1 ВУ2 ВУ3

Механизм

Носитель  
 информации

Рис.10.1

При прямом вводе-выводе работа внешних устройств и памяти управляется центральным процессором, и все они подключаются к одной системной шине, при этом в зависимости от варианта подключения памяти может быть: в случае 1 – одно пространство адресов памяти и портов внешних устройств, а в случае 2 – отдельные адреса обращения к памяти и внешним устройствам. Процесс взаимодействия внешних устройств и центральной части машины определяется интерфейсом ввода вывода, под которым понимается совокупность сигналов, линий связи и алгоритмов управления, обеспечивающих заданный протокол взаимодействия внешних устройств и процессора. Под протоколом понимается последовательность формирования прямых и квитирующих сигналов взаимодействия (ответный сигнал называется квитирующим).

ВУ1 ВУ2 ВУ3 ВУ4

Контроллер 1 Контроллер 2

Канал 1

(Мультиплексный)

ЦП ОП

Канал 2 Контроллер ВУ (Селекторный)

Рис.10.2

На рис10.2 показан процесс ввода-вывода по способу, называемому канальным.

Каналы делятся на следующие.

1. Мультиплексные (обслуживают много ВУ, но медленных).
2. Селекторные (обслуживают мало ВУ, но быстродействующих).

Отличительная особенность канального ввода-вывода - процессор освобождается от управления внешними устройствами, функция процессора заключается в инициализации запуска канальных программ и завершении операции ввода-вывода, выполняемой с помощью канала, по соответствующему признаку из канала (по существу это многопроцессорная система).

***Состав и сравнение функций контроллеров и каналов***

*Контроллер*

1. В текущий момент времени он выполняет одну команду ввода-вывода, получаемую от процессора или канала, и одновременно обслуживает одно внешнее устройство.

В его функции входит:

1. Опознание своего адреса выборки.
2. Подтверждение готовности внешних устройств.
3. Управление операцией во внешнем устройстве.
4. Согласование форматов данных.
5. Согласование скоростей передачи (буферизация).
6. Фиксация момента и характера операции ввода-вывода.

Контроллер должен содержать:

1. Селектор адреса (логическая схема, выдающая разрешающий сигнал на один адрес).
2. Регистры управления (содержит команду) и состояния. Состояния характеризуются следующими битами: DONE, BUSY, ERROR, часто применяются биты приоритета.
3. Буферные регистры данных, которые служат для согласования форматов и скоростей передачи.

*Канал*

1. Выполняет целую канальную программу из многих команд.
2. Допускает одновременное управление несколькими внешними устройствами.

В его функции входит:

1. Опознание своего адреса и подтверждения готовности.
2. Прием команд процессора, инициализирующих работу канала, и нахождения в памяти своей канальной программы.
3. Поиск контроллера и внешнего устройства, участвующего в операции, и проверки их готовности.
4. Запуск канальной программы и управление обменом.
5. Сообщение центрального процессора о завершении операции и всей программы.

Канал представляет собой специализированный процессор с расширенными управлениями, и ограниченный арифметическими возможностями.

# 10.3. Способы выполнения операции передачи данных

Классификация основных способов выполнения передачи данных показан на рис. 10.3, а на рис.10.4-17.7 представлены схемы выполнения каждого из способов передачи данных.

Передача данных

Синхронная Асинхронная

Несовмещенный Вв/выв по программному

вв/выв прерыванию

Вв/выв по аппаратному

прерыванию

Рис 10.3

***Синхронная передача данных***

|  |  |
| --- | --- |
| ↓ | ← Команда вв/выв |
| Передача 1 |  |
| ↓ | ← Команда вв/выв |
| Передача 2 |  |
| ↓ |  |

Рис. 10.4. Синхронная передача данных - самый быстрый, но ненадежный способ передачи данных.

***Несовмещенный ввод-вывод***

Команда

Вв/выв

Фоновая

программа Нет ВУ

готово?

Да

Передача

Рис.10.5

……

В данном случае центральный процессор после выдачи команды ввода-вывода ожидает готовности ВУ, проверяя установку флажка готовности (говорят, что процессор «висит» на флажке готовности). Этот бит представляет собой своеобразный семафор, который управляет доступом к данным либо от процессора, либо от ВУ. Такой способ обмена удобен для внешнего устройства и не эффективен для процессора. Так как ВУ диктует условия, то со стороны ВУ скорость передачи данных – максимально для него возможная. Иногда удается в цикле ожидания вставить выполнение процессором фоновой программы.

***Ввод-вывод по программному прерыванию***

Основная программа(ОП)

Запрос ВУ

Подпрограмма

обслуживания

ВУ (передача)

…….

(команда Вв/вывода)

Продолжение ОП

Рис. 10.6

В данном случае ВУ для осуществления передачи устанавливает запрос на прерывание работы процессора и, если прерывание возможно, то подпрограмма обслуживания прерывания выполняет передачу данных, по завершении которой происходит возврат на продолжение основной программы.

Данный способ обмена удобен для процессора и неэффективен для ВУ, в таком режиме к процессору подключаются медленные устройства с произвольными моментами готовности к передаче данных.

***Ввод-вывод по аппаратному прерыванию (прямой доступ к памяти)***

Основная программа

(Инициализация ПДП)

Запрос 1

на передачу

цикл памяти

(передача 1)

Запрос 2

на передачу цикл памяти

(передача 2)

Рис. 10.7

Процесс передачи осуществляется без участия центрального процессора под управлением котроллера прямого доступа в память (ПДП). Процессор только производит начальную настройку контроллера ПДП, а затем выполняет собственную программу. В моменты готовности данных к передаче у процессора только занимается один цикл памяти, необходимый для выполнения передачи. В таком режиме обычно выполняется передача блоков данных для уменьшения накладных расходов, связанных с инициализацией контроллера ПДП перед операцией ввода-вывода.

Этот режим обеспечивает параллельную работу процессора и выполнение операций ввода-вывода, он используется для подключения быстрых ВУ, так как передача идет между памятью и ВУ, и управление передачей происходит аппаратно.

# 10.4. Структуры контроллеров ВУ для различных режимов передачи данных

*Контроллер несовмещенного ввода-вывода (КНВВ)*

С ШУ (состояние) & РгУС

и

с Done Err Выв/Вв т ША

е Селектор

м адреса

н

а ШУ(команды) & ВУ

я

ш & РгД

и ЩД (Выв) Вв

н

а &

ЩД (Вв)

Выв

Рис.10.8

На рис. 10.8 показан контроллер несовмещенного ввода-вывода.

Основы узла контроллера несовмещенного ввода-вывода (КНВВ):

* Селектор адреса, который выдает на выходе единицу (разрешающий сигнал), только для одного адреса (своего адреса);
* РгУС – регистр управления и состояния, который принимает от шины управления команду ввода-вывода, а на выход передает состояние ВУ до и после выполнения команды.
* БРгД – буферный регистр данных осуществляет промежуточное хранение данного для согласования форматов и выравнивания скоростей ВУ и процессора.

*Контроллер обмена по программному прерыванию(ОПП)*

Контроллер ОПП состоит из двух частей:

1. Индивидуальный контроллер управления ВУ (аналогичен КНВВ).
2. Общий или выделенный контроллер обслуживания прерываний.

С НВП

И IRR

С (ША)

Т

Е

М INT IRQ N &

Н (ШУ) ISR

А

Я

(ШУ)

Ш

И IMR

Н

А

IM

PRIOR

(ШД) EI DONE PRIOR … РгУс

Контроллер прерываний КНВВ

Рис. 10.9

INTA

INTA

На схеме рис. 10.9 используются обозначения:

IRR – регистр приема запросов, ISR – регистр обслуживания запросов,

IMR – регистр маскирования прерываний, PRIOR – арбитр, схема разрешения приоритетов,

IM – маска прерывания (выдается по шине данных ШД),

Int – линия шины управления ШУ для выдачи запроса прерывания в процессор,

Inta – линия ШУ для подтверждения разрешения на прерывание,

НВП – Номер Вектора Прерывания (выдается по шине адреса ША),

EI – бит разрешения прерывания в РГУС КНВВ,

Done – бит завершения операции ввода-вывода в РГУС КНВВ.

Если сигнал INTA = ‘разрешено', то тогда контроллер прерываний выставляет НВП на ША.

Далее идет обычная передача данных через КНВВ с той разницей, что процессор не висит на флаге ожидания. Удобно для процессора, но неудобно для ВУ, так как устройство должно ожидать, пока контроллер получит разрешение от процессора на прерывание.

*Контроллер передачи данных в режиме аппаратного прерывания  
 (или прямого доступа к памяти – КПДП)*

(ЦП) КПДП

BACK DACK

Контр. CAR CWR Mode R КВУ

шины (Рг ТА) (Сч Слов) (Рг Реж)

BRK DRQ

Внутренняя шина

Контр. BAR BCR Управ- ША

прерыв. (Рг БА) (Рг БС) ление ШД

ШУ

ШУ ША ШД ШУ

С и с т е м н а я ш и н а

РиР

Рис. 17.3

Основные компоненты КПДП

CAR – регистр текущего адреса – работает в режиме автоинкрементирования; увеличивается на 1 или 2 после каждой передачи байта или слова данных.

CWR – счетчик слов (или байт), который работает в режиме автодекрементирования: после каждой передачи содержимое регистра уменьшается на 1(байт) или 2 (слово).

ModeR – регистр режима передачи (определяет характер и направление передачи).

BAR – регистр базового адреса, содержит начальный адрес памяти и в процессе передачи не изменяется (служит для средств контроля передачи).

BCR – регистр базового счетчика, содержит первоначальное количество передаваемых слов (служит для средств контроля передачи).

Управление – управление организацией передачи по внутренней шине КПДП.

По ШУ в КПДП передаются следующие сигналы:

MemR - чтение памяти

IOR - чтение устройства

MemW - запись памяти

IOW - запись устройства

В режиме прямого доступа к памяти выполняется блочная передача данных между памятью и быстрыми ВУ (HDD, Sound card и т. д.). Управление передачей происходит без участия процессора (процессор должен только инициализировать регистры контроллера).

В обеспечении передачи задействованы все три вида контроллеров:

1. Контроллер ПДП.
2. Контроллер прерываний, который в данном случае формирует сигнал в процессор о завершении передачи в режиме прямого доступа в память.
3. Индивидуальный контроллер КНВВ, управляющий операцией Вв/выв в конкретном ВУ.

*Алгоритм передачи данных в режиме ПДП*

1. После подготовки устройством данного (или готовности к приему очередного данного) оно выставляет запрос DRQ на передачу в режиме прямого доступа.
2. По его получении КПДП выставляет запрос BRK на возможность захвата шины.
3. Вырабатывается подтверждающий сигнал BACK от контроллера памяти.
4. Вырабатывается подтверждающий сигнал DACK от КПДП к внешнему устройству.
5. Далее выдается пара команд: либо {MemR и IOW}, либо {MemW и IOR }, реализующие собственно передачу данного между ВУ и памятью.
6. После этого сбрасывается сигнал запроса шины и разрешения доступа к памяти: BRQ ← 0, DACK ← 0.
7. Изменяется содержимое регистра РгТА: TA ++ и счетчика слов: CC -- .

Пункты с 1 по 7 называются «занятие цикла памяти» и выполняются для передачи одного данного. Они повторяются до тех пор, пока не выполнится условие СС = 0, по которому формируется запрос в контроллер прерываний, в результате обслуживания которого процессор узнает о завершении передачи блока данных в режиме ПДП.

В компьютерах iХ86 в качестве КПДП используются микросхемы:

1. 8237A – XT (содержит четыре канала с номерами 0–3, работает с однобайтовыми портами).
2. 8237A – 5 – AT и выше (содержит две группы по четыре канала, первая – как у XT (для поддержки), а вторая – для работы с двухбайтовыми портами).

***Состав регистров и адресация 8237A:***

00h – 07h – номера регистров по каждому из каналов.

0Ah регистр маски разрешает и запрещает работу по каждому из каналов.

номера битов:

0, 1 – номер канала

2 – разрешить, запретить

3…7 – не используются

0Bh – регистр режима

номера битов:

0, 1 – номер канала

2, 3 – тип цикл DMA

00 – цикл проверки

01 – цикл занятости

10 – цикл чтения

11 – запрещенная комбинация

4 – режим инициализации

5 – направление приращения адреса

0 – увеличение

1 – уменьшение

6, 7 – режим обслуживания

00 – по требованию

01 – одиночная передача

10 – блочная передача

11 – каскадирование (использование двухуровневых контроллеров)

0Ch – сброс триггеров байта

0Eh – сброс регистра маски

81h…8Fh – регистры страниц, текущий адрес равен 16 бит, шина адреса и шина данных (прямого доступа к памяти) равны 20 бит, регистры страниц задают адрес страницы (старшие четыре бита адреса – работают с 1 Мб), одна страница – 64 Кб.

Для 8237A-5-AT используются 3-байтовые регистры страницы (24 бит) и появляется возможность адресовать до 16 Мб оперативной памяти.

# Программные средства управления вводом-выводом (ПС УВВ)

# Состав ПС УВВ

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | | | | | | | ПСУВВ | | | | | |  | | | | |
|  | | | | | | | | | |  | | | | | | | |
| Управление данными | | | | | | | |  | | | | Управление устройствами | | | | | | |
| ↓ |  | ↓ |  | ↓ |  | ↓ | | |  | | ↓ | | |  | ↓ |  | ↓ |
| Блочно–ориент. I/O | Записе- ориен. I/O | FCB доступ | FH доступ | | | Распред. ВУ между задачами | | | Подсистема буфери-зации | Драйверы внешних устройств |

Рис. 11.1

На рис.11.1 показаны две основных части ПС УВВ: управление данными и управление устройствами.

Подсистема управления данными обеспечивает:

- блочно-ориентированный ввод-вывод для файлов последовательного доступа;

- записе-ориентированный ввод-вывод для файлов прямого доступа.

Система управления устройствами содержит три подсистемы:

Диспетчеризация устройств между задачами.

Подсистема буферизации загрузки и выгрузки данных

Набор драйверов для управления операциями ввода-вывода в конкретных ВУ.

# 11.2. Основные компоненты процедуры управления ввода-вывода общего вида

1. Подготовительная (инициализирующая) часть:

Формирование областей для хранения данных и создание указателей на эти области.

Указания типа и логического номера внешнего устройства.

Задание режима передачи данных и направления передачи.

Этот этап обычно реализует процессор, который осуществляет подготовку.

1. Планирование, проверка готовности и запуск устройства.

Выбор канала.

Выбор внешнего устройства.

Замена логических номеров на физические адреса.

Проверка готовности для выполнения операции.

Запуск устройства для работы.

1. Выполнение устройством операции ввода-вывода

Для реализации используются драйверы и программы управления данными

1. Завершение операции ввода-вывода; следовательно освобождаются занимаемые области памяти и устройства, участвовавшие в операции.

# 11.3 Состав и реализация устанавливаемого драйвера символьного типа

Возможны четыре варианта использования драйвера:

1. Непосредственно написание драйвера на уровне битов портов ввода-вывода и включение его в собственную программу; используется в случае редко используемых драйверов и специализированных машин (малоперспективно).
2. Подключение драйвера в оверлейном режиме (сокращение занимаемой области памяти).
3. Написание драйвера как резидентного обработчика прерываний. Достоинство: доступен всем программам. Недостаток: как правило, доступен только из ассемблера.
4. Создание устанавливаемого в операционной системе драйвера, который включается в файл конфигурации config.sys с помощью команды типа device = path\my\_driver

Хорош тем, что драйвер полностью поддерживается средствами операционной системы. Соответственно к нему применимы команды операционной системы вида:

copy a:\ my\_driver c:\drv

Во-вторых, с ним можно работать из языков высокого уровня с помощью операций работы с файлами.

Устанавливаемые драйверы бывают двух типов: блочные и символьные.

Первые используют файловую организацию и передачу данных блоками (обычно применяются для работы с дисковыми накопителями). Вторые используют посимвольную передачу данных (она проще) и применимы к любым внешним устройствам.

Символьный драйвер состоит из следующих элементов:

1. Заголовок драйвера.
2. Процедура стратегии.
3. Буфер запроса.
4. Обработчик прерываний подключает таблицу функций с набором операций, которые могут выполняться данным устройством.

1.  Заголовок драйвера (18 байт)

1. Адрес следующего драйвера (4 байт).
2. Атрибуты (2 байт).
3. Смещение процедуры стратегии (2 байт).
4. Смещение обработчика прерываний (Обр\_прер).
5. Имя устройства (8 байт).

Заголовок драйвера Буфер запроса

1)Адрес след.драйвера 1)Длина буф. запроса

2)Атрибуты 2)Код ВУ

3)Смещение (3) 3)Код команды Вв/выв

4)Смещ. обр-ка прер. (2) 4)Статус

5)Имя устройства 5)Резерв

Процедура стратегии (4) Данные

(5)

Обработчик прерываний (не найден)

| инициализация

ТаблФ | ввод

| вывод

(6) (7)

ПП инициализации

ПП ввода

(функция выполняемой команды)

ПП вывода

(8)

RET статус завершения

возврат

в прикладную

программу

Драйвер обычно записывается как самостоятельный модуль, но без PSP, поэтому не может запускаться самостоятельно.

1. Атрибуты:

15 бит : 1- символьный драйвер

0 – блочный драйвер

14 бит : поддержка IOCTL

13 бит : формат блоков

1 – IBM

0 – любой другой

………

3 бит : 1 – часы

0 – не часы

2 бит : 1 – null

0 – не null

1 бит : 1 – STDOUT (стандарт вывода)

0 - STDIN (стандарт ввода)

2. Процедура стратегии.

Процедура стратегии выполняются только один раз на этапе загрузки и служит для запоминания длинного указателя на буфер запроса, создаваемый для драйвера самой операционной системой.

DEV\_STRAT:

mov cs: SEG\_PQBF, es ;

mov cs: OFF\_PQBF, es ;

ret

SEG\_PQBF DW ?

OFF\_PQBF DW ?

3. Буфер запроса.

Структура данных, через которые прикладная программа связывается с драйвером (прикладная программа задает вид операции ввода-вывода и место расположения данных, а драйвер возвращает ей свой статус (все идет через буфер запроса)).

Буфер состоит их стандартной части 13 байт, называемой заголовок и последующей части, называемой данные, содержащей различную информацию в зависимости от вида драйвера и исполнительной операции ввода-вывода.

Заголовок запроса.

+0 : длина буфера запроса

+1 : код внешнего устройства

+2 : код команды ввода-вывода

+3 : статус

+5 : резерв

+13d : данные

4. Обработчик прерывания.

Это только процедура, которая таблично вызывает функцию, реализующую команду ввода-вывода; она завершается командой RET и выдачей статуса.

Таблицы А.Ф. Ком 1

Функции . . . . . . . . . . .

. . . . . . . . . . .

А.Ф. Ком N

Ф. Ком 1

Функции . . . . . . . . .

. . . . . . . . .

Ф. Ком N

**Код обработчика прерываний**

dev\_intpr: push A

mov ax, SEG\_PQBF ;

mov es, ax ;

mov bx, OFF\_PQBF ;

mov al, es:[bx+2] ;

shl al, 1 ;

xor ah, ah ; Подготовка и загрузка

lea di, FUN\_TAB ; смещения функции

add di, ax ; в таблицу функции

jmp word ptr[DI] ;

FUN\_TAB LABEL WORD;

⎧ DW INITIALIZE

⎪ DW CHECK\_MEDIA

⎪ . . . . . . .

⎪ DW INPUT\_DATA

Тринадцать ⎨ . . . . . . .

функций ⎪ DW OUPUT\_DATA

⎪ . . . . . . .

⎪ DW OUTPUT\_STATUS

⎪ . . . . . . .

⎩ DW IOCTL\_OUT

Определенная функция находится в определенной строке таблицы.

Предположим что драйвер поддерживает только две функции init и out, тогда:

CHECK\_MEDIA:

. . . . . .

INPUT\_DATA:

. . . . . .

IOCTL\_OUT:

or es.word ptr[bx]+3, 8103h

JMP QUIT

INITIALIZE:

lea ax, E\_O\_P

mov es, word ptr[bx]+14, ax

mov es, word ptr[bx]+16, cs

JMP QUIT

OUTPUT\_DATA

QUIT:

OR es:word ptr[bx]+3, 100h

POPA

RET

В поле статус, бит

15 – ошибка

9 – драйвер занят

8 – функция завершена

с 0 – 7 – код ошибки

Пример: 8103h означает 8 – ошибка , 1 – операция завершена, 03 – неизвестная ошибка.

После разработки драйвера нужно вставить его в config.sys

Надо учесть, что драйвер не прощает ошибок. Так как он скрыт от пользователя, поэтому нельзя пользоваться отладчиком.

# Список литературы

1. Таненбаум Э., Остин Т. Архитектура компьютера. 6-е изд. СПб.: Питер, 2014.

2. Паттерсон Д., Хеннесси Дж. Архитектура компьютера и проектирование компьютерных систем. 4-е изд. СПб.: Питер, 2012.

3. Жмакин А.П. Архитектура ЭВМ. 2-е изд. СПб.: БХВ-Петербург, 2010.

4. Орлов С.А., Цилькер Б.Я. Организация ЭВМ и систем. 2-е изд. СПб.: Питер, 2011.

5. Гук М. Аппаратные средства IBM PC. Энциклопедия 2-е изд. СПб.: Питер, 2002.

6. Зубков С.В. Assembler. Для DOS, Windows и Unix. М.: ДМК, 1999.

7. Касперски К. Техника оптимизации программ. Эффективное использование памяти. СПб.: БХВ-Петербург, 2003.

Дополнительная

1. Компьютеры на СБИС: В 2 кн. Кн.1 / Пер. с япон.; Мотоока Т., Томита С., Танака Х. и др. М.: Мир, 1988.

2. Королев Л.Н. Микропроцессоры, микро- и мини-ЭВМ. – М.: Изд-во МГУ, 1988

3. Рудометов Е., Рудометов В. Архитектура ПК, комплектующие, мультимедиа. СПб.: Питер, 2000.

4. Рудаков П.И., Финогенов К.Г. Программируем на языке ассемблера IBM PC. Обнинск: Принтер, 1999.

5. Фрир Дж. Построение вычислительных систем на базе перспективных микропроцессоров / Пер. с англ. М.: Мир, 1990.

6. Фролов А.В., Фролов Г.В. Аппаратное обеспечение персонального компьютера. М.: Диалог-МИФИ, 1997 (Библиотека системного программиста; т.33).

7. Джордейн Р. Справочник программиста ПК типа IBM PC XT и AT / Пер. с англ. М.: Финансы и статистика, 1991.

# ПРИЛОЖЕНИЯ

**П1. Система команд процессора iX86**

***П1.1.  Команды передачи данных***

a)  **MOV** приемник, источник; 8086, пересылка данных.

mov d, s ; (s)🡪d ; d – destination (приемник); s – source (источник).

Команда MOV действует аналогично операторам присваивания в языках высокого уровня. Оба операнда должны быть одного и того же раз­мера – байт, слово или двойное слово. Нельзя выполнять пересылку данных с помощью MOV из одной пере­меной (ячейки памяти) в другую, из одного сегментного регистра в другой, и нельзя поме­щать в сегментный регистр непосредственный операнд. Для пересылок из одного сегментного регистра в другой используют две команды MOV (из сегментного регистра в обычный и уже из него в другой сегментный) или пару команд PUSH/POP (более длинный по времени способ).

b) **XCHG** операнд1, операнд2; 8086, обмен операндов между собой;

автоматически устанавливает режим LOCK

xchg al, ah ;

xchg bx, MEM ;

Содержимое операнда 2 копируется в операнд 1, а старое содержимое операнда 1 –

на место операнда 2.

c) **LEA** приемник, источник; 8086, вычисление эффективного (исполнительного) адреса.

NEAR: lea bx, MEM ; эта команда аналогична команде mov bx, offset MEM.

Вычисляет эффективный адрес источника (переменная) по отношению к началу сегмента (по умолчанию DS) и помещает его в приемник (регистр).

d) **LDS** приемник, источник; 8086, загрузить исполнительный адрес, используя DS.

**LES** приемник, источник; 8086, загрузить исполнительный адрес, используя ES.

FAR: lds bx, MEM ; аналогична трем командам:

{ mov bx, offset MEM ; mov ax, seg MEM ; mov ds, ax }

Операнд-источник для этих команд – всегда переменная в памяти. Смещение адреса этой переменной загружается в РОН – приемник, а сегментная часть адреса – в сегментный регистр, заданный в операции.

e) **PUSH** источник; 8086, поместить данные в стек.

**POP** приемник; 8086, считать данные из стека.

Для пересылок между регистрами обычно применяются в виде пары команд:

**push s**

**pop d**

PUSH помещает содержимое источника в стек. Источником может быть ре­гистр, сегментный регистр, непосредственный операнд или переменная. Фактически эта команда копирует содержимое источника в память по адресу SS:[SP] и уменьшает SP на размер источника в байтах. Начиная с 80286, команда PUSH SP помещает в стек зна­чение SP до того, как эта же команда его уменьшит, в то время как на 8086 SP помещался в стек уже уменьшенным на два.

POP помещает в приемник слово или двойное слово, находящееся в вер­шине стека, увеличивая SP на два. POP выполняет действие, полностью обратное PUSH. Приемником может быть регистр общего назначения, сегментный регистр, кроме CS, или переменная. Если в роли приемника выступает операнд, использующий ESP для косвен­ной адресации, команда POP вычисляет адрес операнда уже после того, как она увеличивает ESP.

Начиная с i386, появились команды **pusha** и **popa** – загрузка и выгрузка 8 регистров общего назначения.

f) **IN** приемник, источник; 8086, считать данные из порта.

Копирует число из порта ввода-вывода, номер которого указан в ис­точнике, в приемник. Приемником может быть только AL, АХ или ЕАХ. Источник – или непосредственный операнд (можно указывать номера портов не больше 255), или DX (можно указывать номера портов до 65535).

g) **OUT** приемник, источник; 8086, записать данные в порт.

Копирует число из источника (AL, АХ или ЕАХ) в порт ввода-выво­да, номер которого указан в приемнике. Приемник может быть либо не­посредственным номером порта, либо регистром DX.

На командах IN и OUT строится все общение процессора с устройствами ввода-выво­да.

***П1.2. Команды арифметических операций над целыми числами***

a) **ADD** приемник, источник; 8086, сложение.

add d, s; s + d 🡪 d

Команда выполняет арифметическое сложение приемника и источ­ника и помещает сумму в приемник. Приемник может быть регистром или переменной, источник может быть числом, регистром или переменной, но нельзя использовать пере­менную одновременно и для источника, и для приемника. Команда ADD никак не различает числа со знаком и без знака, но, употребляя значе­ния флагов CF (перенос при сложении чисел без знака), OF (перенос при сложении чисел со знаком) и SF (знак результата), можно исполь­зовать ее и для тех, и для других.

b) **ADC** приемник, источник; 8086, сложение с переносом

add d, s; s + d + CF 🡪 d

Эта команда во всем аналогична ADD, кроме того, что она выполняет арифметическое сложение приемника, источника и флага CF. Пара ко­манд ADD/ADC используется для сложения чисел повышенной точно­сти.

c) **SUB** приемник, источник; 8086, вычитание.

sub d, s; d – s 🡪 d

Вычитает источник из приемника и помещает разность в приемник. Приемник может быть регистром или переменной, источник может быть числом, регистром или переменной, но нельзя использовать переменную одновременно и для источника, и для приемника. Точно так же, как и ко­манда ADD, SUB не делает различий между числами со знаком и без зна­ка, но флаги позволяют использовать ее и для тех, и для других.

d) **SBB** приемник, источник; 8086, вычитание с заемом.

sbb d, s; d – s – CF 🡪 d

Эта команда во всем аналогична SUB, кроме того, что она вычитает из приемника значение источника и дополнительно вычитает значение флага CF.

e) **СМР** приемник, источник; 8086, сравнение.

cmp d, s; d – s

Сравнивает приемник и источник и устанавливает флаги. Сравнение осуществляется путем вычитания источника (число, регистр или пере­менная) из приемника (регистр или переменная; приемник и источник не могут быть переменными одновременно), причем результат вычита­ния никуда не записывается, единственным результатом работы этой команды оказывается изменение флагов CF, OF, SF, ZF, AF и PF. Обыч­но команду СМР используют вместе с командами условного перехода (Jcc).

f) **MUL** источник; 8086, умножение чисел без знака.

mul bl; bl \* al 🡪 ax

Выполняет умножение содержимого источника (регистр или пере­менная) и регистра AL, АХ, ЕАХ (в зависимости от размера источника) и помещает результат в АХ, DX:AX, EDX:EAX соответственно. Если старшая половина результата (АН, DX, EDX) содержит только нули (ре­зультат целиком поместился в младшую половину), флаги CF и OF ус­танавливаются в 0, иначе – в 1. Значение остальных флагов (SF, ZF, AF и PF) не определено.

g) **IMUL** источник; 8086, 80386, умножение чисел со знаком.

**IMUL** приемник, источник;

**IMUL** приемник, источник1, источник2;

Эта команда имеет три формы, различающиеся числом операндов:

1. IMUL источник: источник (регистр или переменная) умножается на AL, АХ или ЕАХ (в зависимости от размера операнда), и результат располагается в AX, DX:AX или EDX:EAX соответственно.

2. IMUL приемник, источник: источник (число, регистр или переменная) умножается на приемник (регистр), и результат заносится в приемник.

3. IMUL приемник, источник 1, источник 2: источник 1 (регистр или пе­ременная) умножается на источник 2 (число), и результат заносится в приемник (регистр).

Во всех трех вариантах считается, что результат может занимать в два раза больше места, чем размер источника. В первом случае приемник автоматически оказывается достаточно большим, но во втором и третьем случаях могут произойти переполнение и потеря старших бит результата. Флаги OF и CF будут равны единице, если это произошло, и нулю, если ре­зультат умножения поместился целиком в приемник (во втором и третьем случаях) или в младшую половину приемника (в первом случае).

Значения флагов SF, ZF, AF и PF после команды IMUL не определены.

h) **DIV** источник; 8086, целочисленное деление без знака.

div bl; ax / bl 🡪 al, ah частное в al, остаток в ah

Выполняет целочисленное деление без знака АХ или ЕАХ (в за­висимости от размера источника) на источник (регистр или перемен­ная) и помещает результат в AL, АХ или ЕАХ, а остаток – в АН, DX или EDX соответственно. Результат всегда округляется в сторону нуля, аб­солютное значение остатка всегда меньше абсолютного значения дели­теля. Значения флагов CF, OF, SF, ZF, AF и PF после этой команды не определены, а переполнение или деление на ноль вызывает исключение #DE (ошибка при делении) в защищенном режиме и прерывание 0 – в реальном.

i) **IDIV** источник; 8086, целочисленное деление со знаком.

Выполняет целочисленное деление со знаком AL, АХ или ЕАХ (в за­висимости от размера источника) на источник и помещает результат в AL, АХ или ЕАХ, а остаток – в АН, DX или EDX соответственно. Результат всегда округляется в сторону нуля, знак остатка всегда совпадает со знаком делимого, абсолютное значение ос­татка всегда меньше абсолютного значения делителя. Значения флагов CF, OF, SF, ZF, AF и PF после этой команды не определены, а перепол­нение или деление на ноль вызывает исключение #DE (ошибка при де­лении) в защищенном режиме и прерывание 0 – в реальном.

k) **INC** приемник; 8086, инкремент.

inc d; (d) + 1 🡪 d

Увеличивает приемник на 1. Единственное отличие этой команды от ADD состоит в том, что флаг CF не затрагивается. Остальные арифметические флаги (OF, SF, ZF, AF, PF) устанавливаются в соответствии с результатом сложения.

l) **DEC** приемник; 8086, декремент.

dec d; (d) – 1 🡪 d

Уменьшает приемник на 1. Единственное отличие этой команды от SUB состоит в том, что флаг CF не затрагивается. Остальные арифметические флаги (OF, SF, ZF, AF, PF) устанавливаются в соответствии с результатом вычитания.

m) **NEG** приемник; 8086, изменение знака.

neg s; -(s) 🡪 s

Выполняет над числом, содержащимся в приемнике, операцию дополнения до двух. Эта операция эквивалентна обращению знака операнда, если рассматривать его как число со знаком. Если приемник равен нулю, флаг CF устанавливается в 0, иначе – в 1. Остальные флаги (OF, SF, ZF, AF, PF) устанавливаются в соответствии с результатом операции.

***П1.3. Логические команды***

a) **AND** приемник, источник; 8086, логическое И.

and d, s; s & d 🡪 d

Команда выполняет побитовое «логическое И» над приемником и источником (источник и приемник не могут быть переменными одновременно) и помещает результат в приемник. Любой бит результата равен 1, толь­ко если соответствующие биты обоих операндов были равны 1, и равен 0 в остальных случаях.

b) **OR** приемник, источник; 8086, логическое ИЛИ.

or d, s; s ! d 🡪 d

Выполняет побитовое «логическое ИЛИ» над приемником и источником (источ­ник и приемник не могут быть переменными одновременно) и помеща­ет результат в приемник. Любой бит результата равен 0, только если со­ответствующие биты обоих операндов были равны 0, и равен 1 в остальных случаях.

c) **XOR** приемник, источник; 8086, логическое исключающее ИЛИ.

xor d, s; s xor d 🡪 d

Выполняет побитовое «логическое исключающее ИЛИ» над прием­ником и источником (источник и приемник не могут быть переменными одновре­менно) и помещает результат в приемник. Любой бит результата равен 1, если соответствующие биты операндов различны, и нулю, если оди­наковы.

d) **NOT** приемник; 8086, инверсия

not s; ¬(s) 🡪 s

Каждый бит приемника, равный нулю, ус­танавливается в 1, и каждый бит, равный 1, сбрасывается в 0. Флаги не затрагиваются.

e) **TEST** приемник, источник; 8086, логическое сравнение.

and d, s; s & d

Вычисляет результат действия побитового «логического И» над при­емником и источником (источник и приемник не могут быть переменными одновре­менно) и устанавливает флаги SF, ZF и PF в соответствии с полученным результатом, не сохраняя результат (флаги OF и CF обнуляются, значе­ние AF не определено). TEST, так же как и СМР, используется в основ­ном в сочетании с командами условного перехода *(Jcc)*.

***П1.4. Сдвиговые команды***

a) **SAR** приемник, счетчик; 8086, арифметический сдвиг вправо.

**SAL** приемник, счетчик; 8086, арифметический сдвиг влево.

**SHR** приемник, счетчик; 8086, логический сдвиг вправо.

**SHL** приемник, счетчик; 8086, логический сдвиг влево.

Эти четыре команды выполняют двоичный сдвиг приемника вправо или влево на значение счетчика (число или регистр CL, из которого учитываются только младшие пять бит, которые могут принимать значения от 0 до 31). Операция сдвига на 1 эквивалентна ум­ножению (сдвиг влево) или делению (сдвиг вправо) на 2. Так, число 0010b (2) после сдвига на 1 влево превращается в 0100b (4). Команды SAL и SHL выполняют одну и ту же операцию (на самом деле это одна и та же команда) – на каждый шаг сдвига старший бит заносится в CF, **все** биты сдвигаются влево на одну позицию, и младший бит обнуляет­ся. Команда SHR выполняет прямо противоположную операцию: млад­ший бит заносится в CF, все биты сдвигаются на 1 вправо, старший бит обнуляется. Эта команда эквивалентна беззнаковому целочисленному делению на 2. Команда SAR действует по аналогии с SHR, только стар­ший бит не обнуляется, а сохраняет предыдущее значение, так что, например, число 11111100b (-4) перейдет в 11111110b (-2). SAR, таким образом, эквивалентна знаковому делению на 2, но, в отличие от IDIV, округление происходит не в сторону нуля, а в сторону отрицательной бесконечности. Так, если разделить -9 на 4 с помощью IDIV, результат будет -2 (и остаток -1), а если выполнить арифметический сдвиг впра­во числа -9 на 2, результат будет -3. Сдвиги больше, чем на 1, эквива­лентны соответствующим сдвигам на 1, выполненным последователь­но. Схема всех сдвиговых операций приведена на рис. 2.1.

Сдвиги на 1 изменяют значение флага OF: SAL/SHL, устанавливают его в 1, если после сдвига старший бит изменился (т. е. старшие два бита исходного числа не были одинаковыми), и в 0, если старший бит остался тем же. SAR устанавливает OF в 0, и SHR устанавливает OF в значение старшего бита исходного числа. Для сдвигов на несколько бит значение OF не определено. Флаги SF, ZF, PF устанавливаются все­ми сдвигами в соответствии с результатом, значение AF не определено (кроме случая, если счетчик сдвига равен нулю, в котором ничего не происходит и флаги не изменяются).

В процессорах 8086 непосредственно можно задавать в каче­стве второго операнда только число 1 и при использовании CL учиты­вать все биты, а не только младшие 5.

b) **ROR** приемник, счетчик; 8086, циклический сдвиг вправо.

**ROL** приемник, счетчик; 8086, циклический сдвиг влево.

**RCR** приемник, счетчик; 8086, циклический сдвиг вправо через флаг переноса.

**RCL** приемник, счетчик; 8086, циклический сдвиг влево через флаг переноса.

Эти команды осуществляют циклический сдвиг приемника на число бит, указанное в счетчике (число или регистр CL, из которого учитываются только младшие пять бит, принимающие значения от 0 до 31). При выполнении циклического сдвига на 1 коман­ды ROR (ROL) сдвигают каждый бит приемника вправо (влево) на одну позицию, за исключением самого младшего (старшего), который записывается в позицию самого старшего (младшего) бита. Команды RCR, RCL выполняют аналогичное действие, но включают флаг CF в цикл, как если бы он был дополнительным битом в приемнике.

***П1.5. Команды передачи управления***

В состав группы команд передачи управления можно включить:

- команды безусловного и условных переходов;

- команды зацикливания;

- команды вызова подпрограмм и команды возврата из подпрограммы;

- команды вызова прерываний и возврата из прерывания.

**a) Команда безусловного перехода**

**JMP** операнд; 8086, безусловный переход

JMP передает управление в другую точку программы. Операндом может быть непосред­ственный адрес для перехода, а также регистр или переменная, содержащая адрес.

В зависимости от типа перехода различают:

* переход типа *short* (короткий переход) – если адрес перехода нахо­дится в пределах от -127 до +128 байт от команды JMP;
* переход типа *near* (ближний переход) – если адрес перехода находит­ся в том же сегменте памяти, что и команда JMP;
* переход типа *far* (дальний переход) – если адрес перехода находится в другом сегменте.

**b) Команды условного перехода**

**Jcc** операнд; 8086, переход по адресу, задаваемому операндом, если условие перехода сс истинно.

Команда Описание

JA Переход, если выше (CF = 0 и ZF = 0)

JAE Переход, если выше или равно (CF = 0)

JB Переход, если ниже (CF = 1)

JBE Переход, если ниже или равно (CF = 1 или ZF = 1)

JC Переход, если перенос (CF = 1)

JCXZ Переход, если регистр CX равен 0

JE Переход, если равно (ZF = 1)

JZ Переход, если 0 (ZF = 1)

JG Переход, если больше (ZF = 0 и SF = OF)

JGE Переход, если больше или равно (SF = OF)

JL Переход, если меньше (SF <> OF)

JLE Переход, если меньше или равно (ZF=1 или SF <> OF)

JNA Переход, если не выше (CF = 1 и ZF = 1)

JNAE Переход, если не выше или равно (CF = 1)

JNB Переход, если не ниже (CF = 0)

JNBE Переход, если не ниже или равно (CF=0 и ZF=0)

JNC Переход, если нет переноса (CF = 0)

JNE Переход, если не равно (ZF = 0)

JNG Переход, если не больше (ZF = 1 или SF <> OF)

JNGE Переход, если не больше или равно (SF <> OF)

JNL Переход, если не меньше (SF = OF)

JNLE Переход, если не меньше или равно (ZF=0 и SF=OF)

JNO Переход, если нет переполнения (OF=0)

JNP Переход, если нет контроля четности (PF = 0)

JNS Переход, если нет знака (SF = 0)

JNZ Переход, если нет нуля (ZF = 0)

JO Переход, если переполнение (OF = 1)

JP Переход, если контроль четности (PF = 1)

JPE Переход, если контроль на проверку четности (PF = 1)

JPO Переход, если контроль на проверку нечетности (PF = 0)

JS Переход, если знак отрицательный (SF = 1)

JZ Переход, если ноль (ZF = 1)

Команды условного перехода (за исключением команды JCXZ) проверяют флаги, которые были установлены предыдущей командой. Условия для каждой мнемонической формы команды даны в круглых скобках выше после каждого описания. Термины «меньше» и «больше» используются при сравнении целых со знаком; «выше» и «ниже» – для целых без знака. Если условие выполняется, то происходит переход по адресу, задаваемому операндом, иначе – выполняется команда, следующая за командой условного перехода. Использование данной команды наиболее эффективно, когда цель условного перехода находится в текущем кодовом сегменте и в пределах от -128 до +127 байт относительно первого байта следующей команды. Если цель команды условного перехода находится за пределами -128 до +127 байт относительно первого байта следующей команды, используйте команду с противоположным условием перехода в сочетании с командой безусловного перехода.

Команда JCXZ отличается от других команд условного перехода тем, что она проверяет не флаги, а содержимое регистра CX на равенство 0. Команда JCXZ полезна в начале условного цикла, который заканчивается командой условного перехода к началу цикла (например, LOOPNE метка цели). Команда JCXZ предотвращает нахождение в цикл при регистре CX, равном нулю, что может привести к выполнению цикла 64К раз вместо нуля раз.

**с) Команды зацикливания**

**LOOP** метка; 8086, повторить цикл (декремент CX и возврат на метку), если (CX) ≠ 0.

Команда LOOP уменьшает содержимое регистра СХ на 1 и выполняет переход типа short (на расстояние [-128, +127] байт от команды Loop). Эта команда используется для организации циклов с регистром СХ в качестве счетчика и эквивалентна паре команд: { dec CX ; jnz метка }, но не меняет значения флагов. Для принудительного выхода из цикла до исчерпания заданного числа повторений используются команды **LOOPcc,** где сс – дополнительное условие перехода, комбинируемое по «И» с условием (CX) ≠ 0.

**LOOPE** метка; 8086, повторить цикл, пока равно ( если (CX) ≠ 0 & ZF=1)

**LOOPZ** метка; 8086, повторить цикл, пока ноль ( если (CX) ≠ 0 & ZF=1)

**LOOPNE** метка; 8086, повторить цикл, пока не равно ( если (CX) ≠ 0 & ZF=0)

**LOOPNZ** метка; 8086, повторить цикл, пока не ноль ( если (CX) ≠ 0 & ZF=0)

**d) Команды вызова подпрограмм и команды возврата из подпрограммы**

**CALL** операнд; 8086, переход на подпрограмму с возвратом.

Сохраняет адрес следующей команды в стеке и передает управление по адресу, указанному в операнде. Операндом может быть непосредственное значение (метка в ассемблере), регистр или переменная, содержащие адрес перехода. Если подпрограмма размещена в том же сегменте, что и команда CALL, то выполняется ближний вызов подпрограммы: прямой (на метку) или косвенный (через регистр или переменную). При этом в стеке сохраняется текущее значение IP, а в IP загружается смещение адреса подпрограммы. Если подпрограмма размещена в другом сегменте, нежели команда CALL, то в стеке сохраняются текущие значения CS и IP, а в CS и IP загружаются сегмент и смещение адреса подпрограммы.

**RET (RETN, RETF)** [число]; 8086, возврат из подпрограммы

Cчитывает из стека слово (RETN) или два слова (RETF) в зависимости от описания подпрограммы (ближнего или дальнего вызова) и загружает их соответственно в IP или в IP и CS. Операнд-число для RET не обязателен, но, если он присутствует, после считывания адреса возврата из стека будет удалено заданное этим числом количество байт.

**e) Команды вызова прерываний и возврата из прерывания**

**INT** операнд; 8086, вызов процедуры обработчика прерывания

**|INTO** ; 8086, прерывание 4 – если флаг переполнения равен 1

Команда INT n генерирует вызов «обработчика прерывания». Непосредственный операнд – целое число от 0 до 0FFh, задает номер индекса в таблице векторов прерываний (в старших моделях – дескрипторов прерываний) для вызываемой подпрограммы «обработчика прерывания». Таблица векторов прерываний представляет собой массив из указателей дальнего вызова длиной в четыре байта, начинающийся по адресу 0000h : 0000h. Первые 32 прерывания резервированы Intel для системных целей. Некоторые из этих прерываний используются для внутренних исключений.

Команда INT n помещает в стек содержимое регистра флагов, регистров CS и IP в указанной последовательности и затем выполняет переход к дальнему указателю, индексируемому номером прерывания.

Условная команда INTO идентична команде прерывания INT n, за исключением того, что номер прерывания неявно устанавливается равным 4, и прерывание происходит только при установленном флаге переполнения процессора.

**IRET** ; 8086, возврат из прерывания

|Команда IRET извлекает из стека указатель команд IP, регистр CS и флаговый регистр, после чего возобновляет выполнение прерванной программы.

***П1.6. Команды обработки строк***

Все команды работы со строками считают, что строка-источник находится по адресу DS:SI, а строка-приемник – по адресу ES:DI. Кроме того, все строковые команды за один раз выполняют операцию только с одним элементом строки (байтом, словом или двойным словом). Для выполнения операций над всеми элементами строки необходимо задать один из префиксов повторения операций: REP (Повторять), REPE (Повторять, пока равно), REPZ (Повторять, пока ноль), REPNE (Повторять, пока не равно), REPNZ (Повторять, пока не ноль). По аналогии с командами LOOP префиксы используют регистр СХ в качестве счетчика повторений, уменьшая его при каждом выполнении на 1, и комбинируют по «И» проверку условия (CX) = 0 с дополнительным условием, определяемым названием префикса: (ZF = 1) – для REPE, REPZ и (ZF = 0) – для REPNE, REPNZ. Обычно префикс REP используется с командами MOVS, LODS, STOS, INS и OUTS, а остальные префиксы – с командами CMPS и SCAS.

**MOVS/ MOVSB/MOVSW/MOVSD** приемник, источник; 8086, копирование строки

Команда копирует элемент строки из памяти по адресу DS:SI в память по адресу ES:DI.

Эта и все последующие строковые команды имеют разновидности вида **MOVSB, MOVSW** и **MOVSD** (только для i386 и выше) для задания операции над байтом, словом иди двойным словом. Если используется форма MOVS,то тип операнда определяет сам ассемблер.После того, как копирование выполнено, происходит автоматическое продвижение регистров SI и DI. Если флаг DF равен 0 (т.е. была использована команда CLD), происходит инкремент этих регистров; если же флаг DF равен 1 (была выполнена команда STD), то происходит декремент регистра. При копировании байтов выполняется инкремент или декремент на 1, при копировании слов на 2. Команде MOVS может предшествовать префикс REP для блочного сравнения с использованием CX байтов или слов.

**LODS/LODSB/LODSW/LODSD**  источник; 8086, загрузка строки

Команда LODS загружает регистр AL, AX или EAX байтом, словом или двойным словом памяти из адреса, на который указываеи регистр SI. После выполнения загрузки регистр SI автоматически продвигается на 1 при загрузке байта, на 2 при загрузке слова и на 4 при загрузке двойного слова. Команде LODS может предшествовать префикс REP; однако команда LODS чаще используется в конструкции цикла LOOP, поскольку далее обычно следует обработка данных, загруженных в регистры AL, AX или EAX.

**STOS/STOSB/STOSW/STOSD** приемник; 8086, сохранение строки

Команда STOS сохраняет содержимое регистра AL, AX или EAX в байт, слово или двойное слово памяти, заданное адресом, на который указывает регистр DI (EDI) относительно сегмента в регистре ES. Переопреде-ление сегмента не допускается. Адрес назначения определяется содержимым регистра DI, а не явно заданным операндом команды STOS. Этот операнд используется только для удостоверения адресуемости сегмента ES и определения типа данных. Перед выполнением команды STOS следует загрузить в регистр DI или EDI правильное значение индекса. После сохранения элемента строки регистр DI автоматически продвигается на 1 при сохранении байта, на 2 при сохранении слова и на 4 при сохранении двойного слова. Команде STOS может предшествовать префикс REP для заполнения блока из CX или ECX байтов, слов или двойных слов.

**INS/ INSB/INSW/INSD** приемник, источник; 8086, ввод строки

**OUTS/OUTSB/OUTSW/OUTSD** приемник, источник; 8086, вывод строки

**CMPS/CMPSB/CMPSW/CMPSD** приемник, источник; 8086, сравнение строковых данных

Команда CMPS сравнивает байт, слово или двойное слово, на которое указывает регистр SI, с байтом, словом или двойным словом, на которое указывает регистр DI. Сравнение выполняется посредством вычитания операнда, индексированного регистром DI, из операнда, индексированного регистром SI. Отметим, что направление вычитания для команды CMPS: [SI] – [DI] противоположно направлению, принятому по обычным соглашениям Intel, где левый операнд является назначением, а правый – источником. Результат вычитания не записывается; он отражается только изменением флагов. После того, как сравнение выполнено, происходит автоматическое продвижение в регистрах SI и DI. Команде CMPS может предшествовать префикс REPE или REPNE для блочного сравнения с использованием CX-байтов или слов.

**SCAS/SCASB/SCASW/SCASD** приемник; 8086, сравнение строковых данных

Команда SCAS вычитает байт или слово памяти, задаваемое регистром DI, из регистров AL, AX или EAX. Результат ***отбрасывается***; происходит только установка флагов. Операнд должен адресоваться относительно сегмента в регистре ES; переопределение сегмента не допускается. После того, как сравнение выполнено, регистр назначения автоматически обновляется. Команде SCAS может предшествовать префикс REPE или REPNE для поиска в блоке CX или ECX байтов или слов.

***П1.7. Команды работы с флагами***

**CLC** ; 8086, Очистить флаг переноса

Команда CLC очищает флаг CF (CF <-0). На другие флаги или регистры она не влияет.

**CLD** ; 8086, Очистить флаг направления

Команда CLD очищает флаг направления DF (DF <-0). На другие флаги или регистры она не влияет. После выполнения команды CLD строковые команды будут инкрементировать используемые ими индексные регистры (SI/DI).

**CLI** ; 8086, Очистить флаг прерывания

Команда CLI очищает флаг прерывания IF (IF <-0), если текущий уровень привилегированности как минимум равен IOPL. На другие флаги она не влияет. Внешние прерывания не распознаются в конце команды CLI и, начиная с этого момента, до установки флага IF.

**CMC** ; 8086, Дополнение флага переноса

Команда CMC изменяет на противоположное значение флага CF (CF <- NOT CF) . На другие флаги влияния не оказывает.

**STC** ; 8086, Установка флага переноса

Команда STC устанавливает флаг CF (CF <- 1)

**STD** ; 8086, Установка флага направления

Команда STD устанавливает флаг направления DF (DF <- 1), в результате чего все последующие строковые операции будут выполнять декремент индексных регистров (E)SI или (E)DI, с которыми они работают.

**STI**  ; 8086, Установка флага прерывания

Команда STI устанавливает флаг IF (IF <- 1). После выполнения следующей команды процессор может реагировать на внешние прерывания, если эта следующая команда оставляет флаг IF в состоянии, разрешающем прерывания. Если внешние прерывания запрещены, и после команды RET использована команда RET (например, в конце подпрограммы), то команда RET будет выполнена до того, как начнут распознаваться внешние прерывания. Также, если внешние прерывания запрещены и использована команда STI, а за ней команда CLI, то внешние прерывания не будут распознаваться, поскольку команда CLI очищает флаг IF во время своего выполнения.

**PUSHF** ; 8086, Помещение в стек флаговых регистров

Команда PUSHF декрементирует указатель стека на 2 и копирует регистр FLAGS в новую вершину стека.

**POPF** ; 8086, Извлечение из стека регистров FLAGS

Команда POPA снимает с вершины стека слово и помещает его во флаговый регистр.

***П1.8. Команды математического сопроцессора FPU***

**a) команды пересылки данных**

**FLD** ; Загрузка действительного значения в стек

Работа команды: Декремент указателя TOP вершины стека FPU; ST(0) <- SRC;

Команда загружает действительное число в стек сопроцессора из памяти (или из другого регистра). Загружается регистр FPU, расположенный на вершине стека (определяется указателем TOP), обозначаемый здесь и далее ST(0) или просто ST. Если исходное число задано в регистре стека, то используется его номер, который был до декремента указателя вершины стека. В частности, FLD ST(0) дублирует вершину стека.

**FILD** ; Загрузка целочисленного значения в стек

Работа команды: Декремент указателя вершины стека FPU; ST(0) <- SRC;

Команда FILD преобразует исходный целочисленный операнд со знаком, хранящийся в памяти (или в другом регистре), в формат расширенного действительного и помещает его в стек.

**FLD1/FLDL2T/FLDL2E/FLDPI/FLDLG2/FLDLN2/FLDZ** ; Загрузка константы в стек

Работа команды: Декремент указателя вершины стека FPU; ST(0) <- CONSTANT;

Описание:

FLD1 – Поместить +1.0 в стек

FLDL2T – Поместить log 210 в стек

FLDL2E – Поместить log 2 *e* в стек

FLDPI – Поместить число π в стек

FLDLG2 – Поместить lg 2 в стек

FLDLN2 – Поместить ln 2 в стек

FLDZ – Поместить +0.0 в стек

Каждая команда загрузки константы помещает в стек FPU одну из указанных выше общепринятых констант (в расширенном действительном формате).

**FLDCW** ; Загрузка управляющего слова

Команда FLDCW заменяет текущее значение управляющего слова FPU значением, находящимся в заданном слове памяти.

**FST/FSTP** ; Сохранить действительное число

Работа команды: DEST <- ST(0); IF команда = FSTP THEN извлечение из стека ST; FI;

Команда FST копирует текущее значение регистра ST в операнд назначения (другой регистр, либо память действительного формата одинарной или двойной точности); при этом аппаратный стек не меняется. FSTP (копирование с очисткой стека) выполняет сначала копирование, а затем извлечение ST из стека. Если источник является регистром, то используется номер регистра, который был до извлечения из стека.

**FXCH** ; Поменять местами содержимое регистров

Работа команды: врем <- ST; ST <- DEST; DEST <- врем;

Команда меняет местами содержимое регистра назначения и вершины стека. Если назначение явно не задано, то используется ST (1). Многие числовые константы работают только с вершиной стека; FXCH обеспечивает простое средство использования этих команд по отношению к нижним элементам стека. Например, следующая последовательность берет квадратный корень из содержимого третьего регистра сверху (предполагая, что ST непустой):

FXCH ST(3)

FSQRT

FXCH ST(3)

**b) команды арифметической обработки**

Выполняют четыре арифметических действия над всеми типами данных. Даже обработка целых чисел в сопроцессоре идет по принципу вещественных чисел.

**FADD/FADDP/FIADD** ; Сложение

Работа команды: DEST <- DEST + SRC; IF команда = FADDP THEN извлечение из стека ST FI;

Команды сложения складывают операнды источника и назначения и возвращают сумму в операнд назначения. Операнд в вершине стека может быть удвоен командой FADD ST, ST(0)

Здесь и далее команда с окончанием Р выталкивает ST(0) из стека: помечает ST(0) как пустой и увеличивает TOP на 1.

**FSUB/FSUBP/FISUB** ; Вычитание

Работа команды: DEST <- ST - Другой операнд; IF команда = FSUBP THEN извлечение из стека ST; FI;

Команды вычитания вычитают из вершины стека другой операнд и возвращают разность в регистр назначения.

**FSUBR/FSUBPR/FISUBR** ; Обратное вычитание

Работа команды: DEST <- Другой операнд - ST; IF команда = FSUBRP THEN извлечение из стека ST; FI;

Команды обратного вычитания вычитают вершину стека из другого операнда и возвращают разность в регистр назначения.

**FCOM/FCOMP/FCOMPP** ; Сравнение действительных чисел

Команды сравнивают вершину стека с источником, который может являться регистром или операндом памяти, являющимся действительным числом одинарной или двойной точности. Если операнд не задан, то ST сравнива-ется с ST(1). После выполнения команды коды условий отражают отношение между ST и исходным операндом.

**FICOM/FICOMP** ; Сравнение целочисленных значений

Команды сравнивают вершину стека с исходным операндом. После выполнения команды коды условий отражают соотношение между ST и исходным операндом.

**FCHS** ; Изменение знака

Команда меняет на противоположный знак ST (знаковый бит ST <- NOT (знаковый бит в ST) ). Эта операция заменяет положительное значение на отрицательное при той же абсолютной величине, и наоборот.

**FMUL/FMULP/FIMUL ;**  Умножение

Работа команды: DEST <- DEST x SCR; IF команда = FMULP THEN извлечение из стека ST FI;

Команды умножения умножают операнд назначения на исходный операнд (источник) и возвращают произведение в операнд назначения.

**FDIV/FDIVP/FIDIV** ; Деление

Команды деления делят вершину стека на прочие операнды и возвращают частное в операнд назначения.

При делении нормального числа на 0 происходит исключение деления на 0 и результат будет бесконечность соответствующего знака. При делении бесконечности на ноль (или любое число) результат – бесконечность, при делении нуля на бесконечность (или любое число) результат – ноль.

**FDIVR/FDIVPR/FIDIVR** ; Деление в обратном порядке

Команды делят другой операнд на вершину стека и возвращают частное в операнд назначения. В остальном эти команды аналогичны предыдущим.

**FTST** ; Тестирование

Работа команды:

CASE (отношение операндов) OF

Не сравнимы: C3, C2, C0 <- 111;

ST > SRC: C3, C2, C0 <- 000;

ST < SRC: C3, C2, C0 <- 001;

ST = SRC: C3, C2, C0 <- 100;

-----------------------------------------------------------------

Флаги FPU | EFlags

-----------------------------------------------------------------

C0 CF

C1 отсутствует

C2 PF

C3 ZF

-----------------------------------------------------------------

Команда тестирования сравнивает вершину стека с 0.0. После выполнения команды коды условий (флаги) отражают результат сравнения.

**FRNDINT** ; Округление к целому

Работа команды: ST <- округленный ST;

Команда округления к целому округляет значение в ST к целому в соответствии с полем RC управляющего слова FPU.

**c) команды вычисления элементарных функций**

**FABS** ; Абсолютное значение

Команда абсолютного значения FABS очищает знаковый бит ST (ST <- 0). Операция оставляет положительное значение без изменений либо заменяет отрицательное значение положительным, равным по абсолютной величине.

**FSCALE** ; Умножение на масштабный коэффициент

Работа команды: ST <- ST x 2\*\*ST(1);

Команда масштабирования округляет значение в ST(1) до целого в сторону нуля, умножает ST(0) на 2 в степени ST(1) и записывает результат в ST(0). Таким образом, FSCALE обеспечивает быстрое умножение или деление на целочисленные степени 2.

Примечание. Команда FSCALE может использоваться как команда, обратная по отношению к FXTRACT. Поскольку FSCALE не извлекает из стека экспонентную часть, за FSCALE должна следовать команда FSTP ST(1), чтобы полностью отменить действие предыдущей команды FXTRACT.

**FXTRACT** ; Выделение экспоненты и мантиссы

Работа команды: врем <- мантисса ST; ST <- экспонента ST;

Декремент указателя вершины стека FPU; ST <- врем;

Команда разделяет значение в ST(0) на экспоненту и мантиссу, экспонента заменяет исходный операнд в ST(0), и затем TOP уменьшается на 1, и в стек помещается мантисса. После выполнения команды ST(0) (новая вершина стека) содержит значение исходной мантиссы, выраженное действительным числом со знаком исходного операнда, а ST(1) содержит значение истинной (несмещенной) экспоненты исходного операнда, выраженное действительным числом.

**FSQRT** ; Квадратный корень

Команда FSQRT заменяет значение в ST(0) на его квадратный корень.

**FSIN** ; Синус

Работа команды:

IF операнд в допустимом диапазоне

THEN

C2 <- 0;

ST <- sin(ST);

ELSE

C2 <- 1;

FI;

Команда FSIN заменяет содержимое ST на sin (ST). Значение ST, выраженное в радианах, должно лежать в диапазоне | O | < 2\*\*63.

**FCOS** ; Косинус

Команда FCOS заменяет содержимое ST на cos (ST). Значение ST, выраженное в радианах, должно лежать в диапазоне | O | < 2\*\*63. Если операнд находится вне допустимого диапазона, то флаг C2 устанавливается, а ST остается неизмененным. Программист сам ответственен за то, чтобы уменьшить операнд до абсолютного значения, меньшего, чем 2\*\*63, вычитая соответствующее число, кратное 2π .

**FPATAN ;**  Частичный арктангенс

Работа команды: ST(1) <- arctan(ST(1)/ST); извлечение из стека ST;

Частичный арктангенс вычисляет арктангенс от ST(1)/ST(0) и возвращает вычисленное значение в радианах в ST(1). Затем выполняется извлечение из стека ST(0). Результат имеет тот же знак, что и операнд из ST(1), и по величине меньше числа π.

**FPTAN** ; Частичный тангенс

Частичный тангенс заменяет содержимое ST на tg (ST) и затем помещает в стек FPU величину 1.0. Значение ST в радианах должно лежать в диапазоне | O | < 2\*\*63.

**F2XM1** ; Вычисление 2Х - 1

Работа команды: ST <- (2ST – 1);

Команда F2XM1 заменяет содержимое ST на (2ST – 1). ST должен находиться в диапазоне -1 < ST < 1. Если операнд находится вне допустимого диапазона, то результат F2XM1 неопределен.

Значения, не равные 2, могут возводиться в степень по формуле XY = 2(Y \* log2X) .

Команды FLDL2T и FLDL2E загружают константы log2 10 и log2 e, соответственно. Команда FYL2X может быть использована для вычисления y \* log2 x для произвольного положительного x.

**FYL2X** ; Вычисление y \* log2 x

Работа команды: ST(1) <- ST(1) \* log2 ST; извлечение из стека ST;

Команда FYL2X вычисляет логарифм ST по основанию 2, умножает логарифм на ST(1) и возвращает полученное значение в ST(1). Операнд в ST не может быть отрицательным. Если операнд в ST отрицателен, то генерируется исключение неверной операции.

**FYL2XP1** ; Вычисление y \* log2 (x +1)

Работа команды: ST(1 ) <- ST(1) \* log2 (ST +1.0); извлечение из стека ST;

Команда FYL2XР1 вычисляет логарифм (ST+1.0) по основанию 2, умножает логарифм на ST(1) и возвращает полученное значение в ST (1). Операнд в ST должен лежать в диапазоне -(1-(кв.корень из 2/2)) <= ST <= кв.корени из 2 -1

**d) Команды управления**

**FINIT/FNINIT** ; Инициализация модуля FPU операций с плавающей точкой

Команды инициализации устанавливают FPU в иcходное состояние, независимо от действий, выполнявшихся им ранее. Управляющее слово FPU устанавливается в значение 037FY (округление до ближайшего, все исключения маскируются, 64-битовая точность представления). Слово состояния очищается (флаги исключений не установлены, регистр стека R0 = вершине стека). Стековые регистры имеют теги «пусто». Указатели ошибки (как команд, так и данных) очищены.

FINIT проверяет наличие немаскируемых исключений ошибок операций с плавающей точкой и обрабатывает их, прежде чем выполнить инциализацию; FNINIT же этого не делает.

**FWAIT** ; Ожидание

Команда FWAIT заставляет процессор проверить наличие необработанных немаскируемых исключений FPU и обработать их, прежде чем перейти к дальнейшему выполнению программы. Эту команду следует указывать в критических ситуациях после команд FPU, чтобы убедиться, что возможные исключения будут обработаны.

**FNOP** ; Отсутствие операции

Эта команда заменяет место и время, но не выполняет никакого действия. Может использоваться для создания задержек в процессе выполнении программы.

***П1.9. Команды MMX (MultiMedia eXtension) расширения***

Эта группа команд появилась, начиная с процессора i586 (Pentium P54C ), ориентирована на обработку мультимедийных приложений и предназначена для повышения эффективности выполнения программ, работающих с большими потоками данных (большими массивами целых чисел) по несложным алгоритмам (обработка графики и видеоизображений, синтез и обработка звука).

MMX расширение включает в себя дополнительные регистры, типы данных и команды, ориентированные на одновременную обработку нескольких целых чисел.

* 1. **Регистры ММХ**

Расширение ММХ использует восемь 64-битных регистра MM0 – MM7, физически размещающихся в поле мантиссы восьми регистров FPU R0 – R7. При записи числа в ММ i поле экспоненты Ri [64-79] заполняется единицами. Кроме того, поле TOP регистра SR FPU и весь регистр тегов TW обнуляются. Поэтому нельзя одновременно пользоваться командами FPU и командами ММХ. При необходимости этого следует пользоваться командами FSAVE / FRSTOR при переходе от команды FPU к ММХ и обратно для сохранения и восстановления регистров FPU или ММХ соответственно.

* 1. **Типы данных**

Расширение ММХ использует 4 новых типа данных:

1. Учетверенное слово (64-битное число).
2. Упакованные двойные слова (два 32-битных двойных слова, упакованных в 64-битное данное).
3. Упакованные слова (четыре 16-битных слова, упакованных в 64-битное данное).
4. Упакованные байты (восемь байт, упакованных в 64-битное данное).

Отличительные особенности обработки данных:

1. Перемещение данных в память или в регистры осуществляется в упакованном виде, а логическая или арифметическая обработка выполняются над каждым элементом (полем) отдельно.

2. Арифметические операции в ММХ используют специальный способ обработки переполнения, который называется «насыщение». Если результат операции больше (меньше) максимального (минимального) значения соответствующего типа данных, то его полагают равным этому максимальному (минимальному) значению. Так, при операциях с цветом насыщение позволяет сохранять чисто белый цвет при переполнении и чисто черный при антипереполнении, а обычная арифметика привела бы к инверсии цвета.

* 1. **Команды ММХ**

(Кроме пересылок все остальные команды начинаются с буквы P.)

1. *Пересылка*

**MOVD** d, s – пересылка двойных слов.

Если приемник – регистр ММХ, двойное слово записывается в его младшую половину (биты 0 – 31), если источник – регистр ММХ, в приемник записывается младшее двойное слово этого регистра.

**MOVQ** d, s – пересылка учетверенных слов.

1. *Преобразование типов (упаковка со знаковым насыщением).*

**PACKSSWB** d, s – упаковывает и насыщает слова со знаком в байты.

Четыре слова, находящиеся в приемнике (регистре ММХ), копируются в четыре младших байта приемника, а четыре слова источника (регистр ММХ или переменная) копируются в старшие четыре байта приемника. Если значение какого-либо слова больше 127 или меньше -128, в байт помещается число +127 или –128 соответственно.

**PACKSSDW** d, s – упаковывает и насыщает двойные слова со знаком в слова.

Аналогично, два двойных слова из приемника копируются в два младших слова приемника, а два двойных слова из источника копируются в старшие два слова приемника.

1. *Распаковка и объединение старших элементов.*

**PUNPCKHBW**  d, s – распаковка байтов и объединение в слова,

**PUNPCKHWD**  d, s – распаковка слов и объединение в двойные слова,

**PUNPCKHDQ**  d, s – распаковка двойных слов и объединение в учетверенное слово.

Команды распаковывают старшие элементы источника (регистр ММХ или переменная) и приемника (регистр ММХ) и записывают их в приемник через один.

Пример:

7 6 5 4 3 2 1 0

7 6 5 4 3 2 1 0

1. *Арифметические операции.*

**PADDB/W/D** d, s – сложение отдельных байтов/слов/двойных слов без учета переноса

**PADDSB/W** d, s – сложение с насыщением

**PADDUSB/W** d, s – сложение без учета знака с насыщением

Аналогичные команды имеются для операций вычитания (**PSUBB/W/D, PSUBSB/W, PSUBUSB/W**).

**PMULHW** d, s – умножение с фиксацией старших слов результатов

**PMULLW** d, s – умножение с фиксацией младших слов результатов

Эти команды умножают каждое из 4 слов источника на соответствующее слово приемника. Затем старшее (младшее) слово каждого из результатов записывается в соответствующую позицию приемника.

**PMADDWD** d, s – умножение со сложением.

Каждое из четырех слов источника умножается на соответствующее слово приемника. Произведения двух старших пар слов складываются и их сумма записывается в старшее двойное слово приемника, а сумма произведений двух младших пар слов записывается в младшее двойное слово приемника (команда применяется при реализации алгоритмов фильтрации изображений и т.п.).

1. *Сравнения.*

**PCMPEQB/PCMPEQW/PCMPEQD**  d, s – сравнение на равенство

Команды сравнивают отдельные байты/слова/двойные слова источника и приемника и в случае их равенства соответствующий элемент приемника заполняется единицами, а иначе – нулями.

**PCMPGTB/PCMPGTW/PCMPGTD** d, s – сравнение на больше .

Команды аналогичны предыдущим, но заполнение приемника единицами происходит, если элемент приемника больше элемента источника.

1. *Логические команды.*

**PAND** d, s – логическое И

**PANDN** d, s – логическое НЕ-И (штрих Шеффера)

**POR** d, s – логическое ИЛИ

**PXOR** d, s – логическое исключающее ИЛИ

Команды выполняют побитовые логические операции над источником и приемником и сохраняют результирующие биты в приемнике.

***П1.10. Расширение AMD 3DNow!***

В процессорах AMD, начиная с AMD 3D, появилось расширение ММХ-команд для обработки как целых, так и пары упакованных 32-битных вещественных чисел:

- дополнительный тип данных: – упакованные 32-битные вещественные числа;

- дополнительный набор команд над этими данными (начинаются с PF: P – это MMX, а F –- float);

- дополнительный набор команд над обычными ММХ-типами данных (упакованными целыми числами).

Дополнительный набор команд расширения AMD 3DNow!включает:

- команды преобразования упакованных целых чисел в упакованные вещественные и обратно;.

- команды сложения, вычитания, сравнения и умножения упакованных вещественных чисел;

- команды вычисления среднего арифметического для упакованных 8-битных целых чисел без знака;

- команды деления и вычисления квадратного корня по итерационным формулам;

- некоторые другие команды.

***П1.11****.****Команды потокового расширения SSE, SSE2***

Команды потокового расширения SSE (Streaming SIMD Extension) появились в процессорах фирмы Intel, начиная с Pentium III, для дополнения набора групповых операций над упакованными целыми числами и выполнения групповых операций над упакованными 32-битными вещественными числами:

- обработка групп целых чисел, упакованных в 64- и 128-битные слова;

- обработка одной пары вещественных чисел одинарной (32 бит) или двойной (64 бита) точности;

- обработка 4 пар вещественных чисел одинарной или 2 пар – двойной точности.

Команды реализуются на дополнительном блоке XMM из восьми 128-битных регистров, названных ХММ0-ХММ7. При выполнении SSE – команд традиционное оборудование FPU не используется, что позволяет эффективно смешивать их с командами FPU. Дальнейшее развитие технологии SSE в процессорах Pentium 4 вылилось в набор команд SSE2, включающих 271 команду, для выполнения различных арифметических и логических операций с обработкой за 1 такт до 4 32-битных чисел с плавающей запятой, упакованных в 128-битное слово.

**П2.** **Краткое введение в программирование на языке Ассемблера**

Ассемблер – машинно-ориентированный язык, предназначенный для написания программ, наиболее эффективных по времени и потреблению ресурсов, или обеспечивающих расширенные функциональные возможности по использованию ресурсов, недоступные из языков высокого уровня. Обычно он используется для написания относительно коротких программ или фрагментов кода, включаемых в программы на языках высокого уровня.

Особенностями ассемблера по сравнению с языком машинных команд являются:

* символическое наименование операций и операндов;
* отсутствие привязки к конкретным адресам памяти;
* возможность специализации программ с помощью макросредств.

Процесс подготовки, трансляции и выполнения ассемблерной программы можно пояснить с помощью схемы, приведенной на рис. П2.1.

Текстовый редактор

Исходный файл

Prog.asm

Транслятор

MASM (TASM)

Файл листинга Объектный файл Таблица символов

Prog.lst Prog.obj Sym.tab

Библиотека стандартных Компоновщик Файлы \*.obj

процедур и функций Link (Tlink) других модулей

Lib.obj

Карта памяти Исполняемый файл Файл перекрестных

Prog.map Prog.exe (.com) cсылок Prog.crf

Отладчик Загрузчик

AFD, TD

Выполнение программы Выполнение программы

под управлением отладчика в автоматическом режиме

Сообщения отладчика Корректные результаты Run Time Errors

Сообщение отладчика Корректные результаты Run Time Errors

Рис. П2.1

Дальнейшее изложение ориентировано на использование ассемблеров Intel 80X86 – MASM и TASM.

***П2.1 Формат оператора ассемблера***

В ассемблере различают два вида форматов:

1. формат исполняемого оператора имеет вид

*[метка:] операция операнд(ы)] [ ; комментарий]*

1. формат директивы имеет вид

*[имя] директива [аргумент(ы)] [ ; комментарий]*

Указанные поля форматов имеют следующий смысл:

- метка/имя символически задает адрес данной команды в исполняемом файле /адрес директивы в исходном тексте;

- операция символически задает дейстие, выполняемое над операндами при выполнении программы;

- директива символически задает действие, выполняемое над аргументами при трансляции программы и генерации объектного файла.

- операнды – имена, числа, символы, участвующие в операции (может быть 0/1/2 операнда);

- аргументы – имена, числа, символы, используемые в директиве (число аргументов не ограничено);

- комментарий – пояснение к тексту программы, при трансляции не рассматривается.

Директива (иногда называется псевдокоманда) ассемблера выполняется на этапе трансляции исходного текста программы в объектный файл, исполняемых машинных команд не порождает.

Исполняемый оператор в процессе трансляции исходного текста порождает машинные команды, которые выполняются на этапе выполнения программы.

***П2.2. Директивы ассемблера***

**1. Директивы задания данных**

1.1. Директивы определения имен

а) *идентификатор EQU выражение*

Позволяет символически именовать константы в программе.

Например

N EQU 100h

TABLE EQU DS:[BP][SI]

MINS\_DAY EQU 60\*24

b) *идентификатор = выражение*

Позволяет символически именовать переопределяемые в программе константы. Используется только для числовых выражений.

1.2. Директивы выделения памяти

Имеет формат:

*идентификатор D\* список значений*

Здесь D\* - одна из приведенных ниже директив:

DB – выделить байты;

DW – выделить слова;

DD – выделить двойные слова;

DF – выделить блоки по шесть байт;

DQ – выделить учетверенные слова;

DT – выделить блоки по десять байт.

Данная директива позволяет зарезервировать в памяти блоки заданного размера и присвоить им, если требуется, определенные значения, заданные в списке. Например:

text\_string db ‘Hello world’ ; выделяет 11 байт и заполняет их кодами символов

b\_max db 255 ; выделяет 1 байт и записывает в него число 255

b\_min db -128 ; выделяет 1 байт и записывает в него число –128

rez\_w dw ? ; выделяет 1 слово и не заполняет его (обычно ; используется в программе для записи результата)

rez\_tab dw 20dup(?) ; выделяет 20 слов, но не заполняет их данными

b\_tab db 4dup(?),8,5,4dup(1); выделяет 10 байт: 4 не заполняются, затем

; записываются числа 8, 5 и четыре раза по 1

fl\_num dd 5.03E-2 ; выделяется двойное слово и в него записывается

; число с плавающей запятой 5.0Е-2.

**2. Директивы сегментации программы**

Два способа задания сегментов в программе.

Полное описание сегментов

имя\_сегмента SEGMENT атрибуты

тело сегмента

имя\_сегмента ENDS

Пример

dat\_s1 segment byte public ‘data’

a db ?

dat\_s1 ends

Атрибуты:

* ReadOnly – сегмент доступен только для чтения; при попытки записи в этот сегмент MASM выдаст сообщение об ошибке.
* Атрибут выравнивания – указывает ассемблеру и компоновщику, с какого адреса может начинаться сегмент.

BYTE – с любого адреса.

WORD – с четного адреса.

DWORD – с адреса, кратного 4.

PARA – с адреса, кратного 16 (установлен по умолчанию).

PAGE – с адреса, кратного 256.

* Атрибут группирования, комбинирования.

PUBLIC- конкатенация (присоединение частей сегментов друг к другу).

COMMON – размещение сегментов данного класса с одного адреса (для сегментов кода и оверлейных программ).

PRIVATE – сегмент с таким атрибутом не объединяется с другими сегментами (значение по умолчанию).

* Атрибут типа данных.

USE16 – сегмент работает с 16-битными данными.

USE32 – сегмент работает с 32-битными данными.

* Атрибут класса – это любая метка, взятая в одинарные кавычки. Этот атрибут влияет на расположение сегментов в скомпонованной программе.

Связь сегментов с соответствующими сегментным регистром.

ASSUME {регистр\_сегментный: имя\_сегмента,…}

Обычно эта директива идет вслед за сегментом кода.

Пример

assume cs: code\_s, ds: d\_seg,

ss: stack, es: nothing

NOTHING – не устанавливать связь или отменить ее, если она была установлена.

Загрузка начальных адресов сегментов в соответствующие регистры.

mov ax, seg d\_seg ; seg- необязательный оператор

mov ds, ax

**3. Директивы группирования.**

GROUP имя\_сегмента1, имя\_сегмента2,…

Все перечисленные сегменты относятся к одной группе и могут адресоваться относительно одного регистра (обычно в одну группу объединяют сегменты одного назначения, например, data и stack).

Сокращенное описание сегментов.

При таком описании требуется обязательное задание модели памяти, в условиях которой используется данная программа.

.MODEL тип\_модели\_памяти

Эта директива накладывает ограничения на комбинирование сегментов (таблица).

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Модель | Тип доступа к коду | Тип доступа к данным | Сегментные регистры | Примечания |
| TINY | Near | Near | (cs)=DGroup  (ds)=(ss)=DGroup | .com |
| SMALL | Near | Near | (cs)=\_Text  (ds)=(ss)=DGroup | .exe |
| MEDIUM | Far | Near | (cs)=<имя\_сегмента>\_Text  (ds)=(ss)=DGroup |  |
| LARGE | Far | Far | (cs)=<имя\_сегмента>\_Text  (ds)=(ss)=DGroup |  |
| HUGE | Far | Far |  |  |

**.CODE** – директива описания сегмента кода; эта запись аналогична

\_TEXT SEGMENT Word Public ‘CODE’

или

<имя\_сегмента> \_TEXT Word Public ‘CODE’

для модели памяти выше MEDIUM

.DATA

\_DATA SEGMENT Word Public ‘DATA’

.STACK

STACK SEGMENT Para Public ‘STACK’

.CONST

CONST SEGMENT Word Public ‘CONST’

.DATA?

\_BSS SEGMENT Word Public ‘BBS’

Отличие от полного описания сегментов заключается в отсутствии директивы ENDS. Таким образом, в результате создаются предопределенные переменные, которые содержат начальные адреса сегментов: @Code, @Data, @Stack, @Const, @BBS. Следовательно, можно написать:

mov ax, @data

mov ds, ax

**4. Порядок размещения сегментов.**

Он важен для того, чтобы уметь определять длину программы, и для возможности работы в отладочном режиме. Обычно компоновщик размещает сегменты в порядке их появления в программе, заданном в главном модуле; для подтверждения такого размещения можно написать:

.SEQ

для размещения в алфавитном порядке:

.ALPHA

размещение сегментов в порядке, принятом в MS DOS:

.DOSSEG

Эти директивы должны располагаться в самом начале программы.

Порядок размещения сегментов, соответствующий .DOSSEG:

* ‘CODE’
* сегменты, не относящиеся к DGROUP (FAR DATE, FAR STACK)
* сегменты DGROUP (‘DATE’, ‘STACK’, ‘BSS’, ‘CONST’)

**5. Директивы ограничения используемых команд.**

По умолчанию используется набор команд процессора i8086 (при попытке исполнить какую-либо другую возникает прерывание). Директивы, определяющие набор допустимых команд:

.ix86 (где x=1,2..6) позволяет использовать команды соответствующих процессоров;

.MXX – возможность применения команд мультимедиа расширения;

.K3D – разрешены команды AMD 3D.

**6. Директива END.**

END [метка старта] – логический конец программы, далее транслятор текст не просматривает. Метка старта – адрес, с которого начинается выполнение программы.

**П2.3. Операции и выражения в ассемблере**

**1. Арифметические операции.**

+, -, \*, /, mod (эти операции выполняются на этапе трансляции)

pi\_int EQU 31416/1000 - целая часть π

pi\_rem EQU 31416 mod 1000 - дробная часть π

SHR\_N - сдвиговые операции (вправо и влево на N двоичных разрядов.

SHL\_R

maska EQU 110010b

maska2 EQU maska SHR\_2

**2. Логические операции.**

Эти операции подразделяются на операции отношения (EQ, NE, LT, LE, GT,GE) и на непосредственно логические (AND, OR, XOR, NOT).

Истина — 0FFFFh

Ложь — 0

mov ax, ((b LT 10) AND 5) OR ((b GE 10) AND 15)

при b=3 предыдущая команда означает: mov ax, 5.

**3. Операции со счетчиком размещения программы (СРП).**

LC – Location Counter

$ – текущее значение СРП, предопределенная переменная.

Message DB ‘Hello!!!’

Mes\_length=$-Message

ORG – директива принудительной установки СРП на константу.

ORG 100h – для \*.com

ORG $+99h – изменение СРП на 99 байт по отношению к текущему значению.

EVEN – задает четное значение СРП (выравнивает СРП на ближайшее четное, большее текущего).

**4. Оператор изменения типа.**

<тип> PTR переменная или метка.

B\_TABLE DB 40DUP

mov ax, B\_TABLE+10

mov ax, word ptd B\_TABLE+10

xword EQU 0FFFCh

xor ax, ax

add al, byte ptr xword ; (AL)=FCh

CALL FAR PTR My\_Sub

**5. Операции выделения сегментной части адреса и смещения.**

SEG – переменная (DS)

OFFSET – метка (СS)

SIZE имя переменной – определяет размер переменной в байтах.

**П2.4. Использование процедур в ассемблере**

Ассемблер относится как к процедурным языкам (Pascal, C, …), так и к непроцедурным. Считается удобным фрагменты текста на ассемблере оформлять в виде процедур, однако CALL far PTR [BX] обращается в произвольное место программы, имя процедуры не используется.

Явное описание процедур:

имя\_процедуры PROC [тип] [язык] [uses regs]

тело процедуры

ret; retf или retn

имя\_процедуры ENDP

тип: far, near (по умолчанию – near);

язык: (по умолчанию – ассемблер);

regs – сохраняются в стеке.

Схема вызова процедуры. При вызове типа NEAR обрабатывание CS не происходит (рис. П2.2)

My\_Proc ENDP

Ret

- - - - - - - - - - - - Стек

My\_Proc PROC IP

CS

- - - - - - - - - - - -

Call My\_Proc CS IP

Рис. П.2.2

Обеспечивается вложенность процедур (ограничена стеком), могут организовываться рекурсивные вызовы. Этапы выполнения процедуры:

* подготовка параметров для работы с процедурой (типы параметров: значения, ссылки, возвращаемые значения, именования (при макровызовах));
* сохранение адреса возврата;
* передача управления на начало процедуры;
* выполнение тела процедуры, включая сохранение регистров, фиксацию результатов, фиксацию кода завершения, восстановление регистров;
* возвращение в основную программу в место после команды вызова, может быть с очисткой стека.

**Способы передачи параметров.**

1. Передача параметров через РОН.

Достоинства: быстрый и удобный;

Недостатки: ограничен в размерах (не более 5).

Применение: написание операционных систем (печать строки и др.).

2. Передача через общую область памяти. (общие переменные)

Общие переменные описываются следующим образом

В вызывающей процедуре

PUBLIC список имен (имена переменных или меток).

В вызываемой процедуре:

EXTRN {имя параметра, тип}

**Пример:**

;головная программа

DATA Segment

EXTERN A:WORD, R:WORD

DATA ENDS

CODE Segment PUBLIC

ASSUME DS:DATA,CS:CODE

PUBLIC PUB\_PROC FAR

start:

mov AX, DATA

mov DS, AX

CALL far ptr pub\_proc

mov cx, ds:A

sub cx, 2

add cx, ds:R

mov ds:A, cx

ret

CODE ENDP

END start

;Модуль, задающий общие переменные и процедуру.

DATA Segment

PUBLIC A, R

A DW 10

B DW 5

C DW 3

B DW 1

DATA ENDS

CODE Segment PUBLIC

ASSUME DS:DATA,CS:CODE

Public Pub\_Proc

Pub\_Proc Proc Far

mov AX, B

add AX, C

mov R, AX

ret

Pub\_Proc ENDP

CODE ENDS

END

3. Передача параметров через стек.

Такой метод применим не только между ассемблерными модулями, но и с разными языками. STDCALL – стандартная взаимосвязь процедур по параметрам. Основным средством доступа к параметрам является BP, для которого:

* его значение при запуске процедуры сохраняется в стеке;
* доступ к параметрам осуществляется с помощью базовой адресации.

Структура стека на момент начала работы с параметрами вызванной процедуры:

(Этот вариант используется в С.)

|  |  |
| --- | --- |
| BP | 🡨 SP🡪BP |
| CS:IP | 🡨 (BP)+2 |
| Par1 | 🡨 (BP)+4/6 |
| Par2 | 🡨 (BP)+6/8 |
| ……… |  |
| ParN | 🡨 (BP)+(N+4)/(N+6) |
| Стек |  |

Вариант для Pascal такой же, за исключением порядка параметров.

Пример:

;main

CODE Segment

EXTERN ADD3UP

Push AX

Push BX

Push CX

CALL ADD3UP

ADD SP,6

CODE ENDS

END start

;процедура обработки

ADD3UP Proc NEAR

Public ADD3UP

Push BP

mov BP, SP

mov AX, [BP+4]

add AX, [BP+6]

add AX, [BP+8]

pop BP

ret

ADD3UP ENDP

4. Передача параметров через поток кода.

Передаваемые параметры размещаются непосредственно в коде программы, сразу за вызывающей командой.

Пример:

Call Print\_It

db ‘печатная строка’

;продолжение программы.

Плюсы: возможность использования любого числа параметров;

Недостатки: доступ косвенный, следовательно медленный.

5. Передача параметров результата.

Передача параметров результатов может быть реализована через стек, AX (BYTE, WORD), DX:AX (DWORD), ST(0) – вершина стека x87 (FLOAT).

**П2.5. Связь ассемблера с языками высокого уровня**

Существует соглашения для связи ассемблера с каждым из языков. Здесь есть свои особенности.

1. Способ передачи управления (тип вызова). В Pascal, если ассемблеровская процедура описана в основной программе или в implementation, то она вызывается как NEAR; при описании в interface–вызов FAR.
2. Сегментация и модели памяти. Если выбрана модель .LARGE, то стек надо описывать как .FARSTACK и он уже не будет относиться к группе DGROUP.
3. Особенности описания общих и предопределенных переменных. В Pascal ограничений нет, но рекомендуется начинать переменные с заглавной буквы; в С-переменных необходимо начинать с символа подчеркивания «\_»
4. Управление регистрами. DS – нужно следить за ним. РОН нужно сохранять или в головной программе, или в процедуре на ассемблере.
5. Способы передачи параметров. Как правило, параметры передаются через кадр стек, размещение параметров идет в различном порядке.
6. Способ возвращения результата. Возвращение результатов может быть реализовано через стек, AX (BYTE, WORD), DX:AX (DWORD), ST(0) – вершина стека x87 (FLOAT).
7. Способ восстановления стека. Pascal – в вызываемой программе, в С – вызывающей программе (для возможности оптимизации)
8. Способы задания и вызова ассемблерного модуля:

а. Раздельная компиляция. Модули на различных языках компилируются отдельно и в вызывающем модуле указан специальный оператор описания модуля на другом языке и его загрузки в виде объекта файла.

б. Встроенная компиляция. Фрагмент или команда ассемблера указывается как встроенный оператор, и сам компилятор вызывает ассемблерный транслятор автоматически.

**Связь ASSEMBLER и PASCAL.**

**Пример 1:**

Test(i, j, k)- вычисляет f=i+j-k; i, j, k∈Z.

i EQU WORD PTR [bp+8]

j EQU WORD PTR [bp+6]

k EQU WORD PTR [bp+4]

.Model Small

.Code

Public Test

Test Proc

Push bp

mov bp, sp

mov ax, i

add ax, j

sub ax, k

pop bp

ret 6

Test EndP

END

Function Test(i,j,k):Word;

External;

{$L Test.obj}

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

F:=Test(i,j,k);

**Пример 2:**

Декодирование символьной строки, которая расположена в области памяти с меткой Buffer длиной Count; кодирование – сдвиг символов на 1 бит влево.

shifr.asm

Code Segment byte Bublic

Assume cs:Code

Public Coder, Decoder

Buffer EQU DWORD PTR [bp+8]

Count EQU DWORD PTR [bp+6]

Cur\_Byte EQU BYTE PTR es:[di]

;FAR вызов Coder(var Buffer, count: word)

Coder Proc

Push bp

mov bp, sp

mov cx, count

jcxz final

les di, Buffer; загрузка смещения с учетом es

cld ; в стороны возрастания адресов

cycle:

moc al, Cur\_Byte

rol al,1

stosb ; переписывает соответствующий символ назад в строку

loop cycle

final:

pop bp

ret 6

Coder EndP

Decoder Proc

Push bp

mov bp, sp

mov cx, count

jcxz final

les di, Buffer; загрузка смещения с учетом es

cld ; в стороны возрастания адресов

cycle:

moc al, Cur\_Byte

ror al,1

stosb ; переписывает соответствующий символ назад в строку

loop cycle

final:

pop bp

ret 6

Decoder EndP

Code EndS

END

Type TMode=(Coder, Decoder);

var Mode:TMode;

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

{$F+}

Procedure Coder (var Buffer, count: word); External;

Procedure Decoder(var Buffer, count: word); External;

{$F-}

{$L shifr.obj}

Begin

Case Mode of

Code: begin

Coder(str1,80);

write(codfile,str1);

end;

Decode: begin

read(codfile,str1);

Decoder(str1,80);

end;

end;

End.

**Пример 3:** на встроенный ассемблер

Написать функцию, которая формирует слово, выбираемое по адресу 0040:006ch (BIOS счетчик таймера).

Function Get\_Time:Longint;

var time:longunt;

begin

asm

push es

mov ax, 0040h

mov es, ax

mov ax, es:[006ch]

mov time, ax

pop es

end;

Get\_Time:=time;

end;

**Пример 4:**

Использование стандартных функций Паскаля в ассемблерном модуле.

DATA Segment Word Public

EXTERN ch:Byte

DATA ENDS

CODE Segment Byte PUBLIC

ASSUME DS:DATA,CS:CODE

EXTERN Readkey: Far

AsmProc Proc Far

Push bp

mov bp, sp

pusha

Call Readkey

mov ch, al

popa

pop bp

ret 2

AsmProc EndP

CODE ENDS

END

**Связь ASSEMBLER и С**

**Пример 1:**

Test(i, j, k)- вычисляет f=i+j-k; i, j, k∈Z.

Вызов из С скомпилировался в

Push WORD PTR DGROUP: \_k

Push WORD PTR DGROUP: \_j

Push WORD PTR DGROUP: \_i

call Near PTR \_TEST

этот вызов порождает кадр стека

|  |  |
| --- | --- |
|  |  |
| 🡪 | BP |
|  | IP |
|  | I |
|  | J |
|  | K |

.Model Small

.Code

Public \_Test

\_Test Proc

Push bp

mov bp, sp

mov ax, [bp+4]

add ax, [bp+6]

pop bp

sub ax, [bp+8]

ret

\_Test EndP

END

**Пример 2:**

Разработать ассемблерный модуль, который вычисляет

|  |
| --- |
| StartVal+Repeat |
| S=Σ i |
| i=StartVal |

total.asm

.Model Small

.Data

Extern \_Repetitions: word

Public \_StartVal DW 0

Total DW ?; локальная переменная

.Code

Public \_Doloop

\_Doloop Proc

mov cx, \_Repetitions

mov ax, \_StartVal

mov Total, ax

cycle:

inc ax

add Total, ax

Loop cycle

mov ax, Total

ret

\_Doloop EndP

END

Call\_Tot.c

extern “c” int Doloop(void);

extern int Repetitions,

StartVal;

main(){

Repetitions=10;

StartVal=2;

print(“%d\n”,Doloop());

}

**Пример 3:** на встроенный ассемблер в программе написанной на С.

Составить встроенную процедуру для заполнения некоторой области памяти размером count байтов заданным символом.

#pragma inline

void memset(void \*dest, char val, short count){

asm{

push es

push di

les di, dest

mov cx, count

mov al, val

mov Total, ax

rep stosb

pop di

pop es

}

}

int main(){

char buf[0x20];

memset(buf,0xFF, size of (Buf));

return 0

}

**П2.6. Макросредства**

Макросы – это еще один способ однократного описания последовательности действий и затем многократного их выполнения с различными параметрами. Основное отличие от использования процедур заключается в том, что макросы – это директивы ассемблеру (обрабатываются они при помощи препроцессорной обработки).

Достоинства:

* они более универсальны, так как позволяют параметрически управлять не только заданием обрабатываемых объектов, но и действиями над этими объектами;
* их использование не связано с выполнением команд CALL и RETURN, поэтому применение макросов ускоряет выполнение программы;
* поскольку описание макросов воспринимается как обычный текст при подстановке, то легко организуются библиотеки макросов.

Недостатки:

* существенное увеличение длины программы, связанное с подстановкой тела макроса во все точки его вызова.

Использование макросов связано с понятиями макроопределение, макровызов, макрорасширение.

Макроопределение – описание действия, выполняющегося макросом применительно к фиксированным параметрам; состоит из заголовка, тела и концовки.

Заголовок: Nam\_Macro MACRO [список фиктивных параметров]

Тело: последовательность операторов

Концевик: END [Nam\_Macro]

Пример1. Макроопределение установки курсора в левый верхний угол экрана.

Home Macro

mov dh, 0

mov dl, 0

mov al, 2; функция перемещения курсора

int 10h ; обработчик управления указателя

ENDM

Пример 2.

Sr\_Mov Macro R1,R2

push R1

pop R2

ENDM

Пример 3.

Add\_W Macro par1, par2, sum

mov ax, par1

add ax, par2

mov sum, ax

ENDM

Макровызов представляет собой директиву ассемблера, помещаемую в текст программы и состоящую из имени макроса и списка фактических параметров, если они требуются. Если список фактических параметров меньше фиктивных, то оставшимся фиктивным параметрам присваиваются нулевые значения. Макрорасширение – это подстановка тела макроса из макроопределения на место макровызова с заменой фиктивных параметров на фактические. Например, макровызов

Sr\_Mov ds,es

при макрорасширении будет заменен на

push ds

pop es

Пример некорректного задания параметра.

Time\_Msg Macro XXX

TimXXX: db ‘сейчас ХХХ часов$’

ENDM

* параметр макроопределения не может быть частью идентификатора;
* параметр макроопределения непосредственно не может использоваться в строке, так как его трудно распознать.

Правильный вариант.

Time\_Msg Macro XXX

Tim&XXX: db ‘сейчас &ХХХ& часов$’

ENDM

Если в теле макроса используется метка, то она должна быть объявлена локальной, чтобы исключить многократное объявление имен.

Пример 4.

Delay Macro count

local cycle

push cx

mov cx, count

cycle: loop cycle

pop cx

ENDM

В макросредствах широко применяются два вида директив (повторения и условные директивы).

**Использование в макросах директив повторения.**

REPT, IRP, IRPC – это встроенные макросы, следовательно должен быть концевик ENDM.

1. REPT

REPT выражение

тело

ENDM

Выражение задает количество раз, которое должно повториться тело. Пример.

REPT 4

shl ax,1

ENDM

При макрорасширении макровызов будет заменен на четыре повторяющихся команды shl ax,1.

Пример 5.

Alloc Macro tlab, lenght

value=0

tlab EQU this byte

rept lenght

value=value+1

db value

ENDM

ENDM

Вызов:

Date Segment

Alloc tab1, 40

Date ENDS

1. IRP

IRP фиктивный\_аргумент, <список значений>

тело

ENDM

Каждый раз из списка подставляется новое значение вместо фиктивного аргумента.

Пример 6.

Savregad Macro

irp r, <ax, bx, dx>

push r

ENDM

ENDM

1. IRPC

IRPC фиктивный\_аргумент, строка

тело

ENDM

При расширении при каждом повторе тела будет подставляться очередной символ из строки.

Пример 7.

IRPC odd5, 13579

db odd5

ENDM

При макрорасширении получим команды db 1, db 3, db 5, db 7, db 9.

Пример 8.

IRPC char, hello

db char

ENDM

При макрорасширении получим команды db h, db e, db l, db l, db o.

Пример 9.

IRPC char, hello

db char

ENDM

При макрорасширении получим команды db ‘h’, db ‘e’, db ‘l’, db ‘l’, db ‘o’.

**Условные директивы**

Позволяют при трансляции программы просмотреть или пропустить фрагмент программы в зависимости от проверки условия.

1. Директивы условной трансляции.
2. Директивы условной генерации ошибок (позволяют выдать соответствующее сообщение об ошибках на этапе трансляции).

Назначение директивы условной трансляции:

1. Написание отладочных версий программ, в которых после завершения отладки можно протранслировать код без соответствующих операторов

(Например Debug = 1).

1. Написание универсальных макросов, настраиваемых на систему.

IF xxx

Операторы (Тело 1)

[ ELSE

Операторы (Тело 2) ]

ENDIF

xxx – некоторое выражение, проверка которого должна давать булевский результат

xxx = 0 Ложь

xxx ≠ 0 Истина

Допускается 255 уровневое вложение.

Существуют предопределенные операторы IF:

IF1 Его тело транслируется только на первом проходе.

Пример10.

IF1

INCLUDE MYLIB

ENDIF

IFE xxx Транслируется, если выражение (xxx) равно нулю.

ALLOC MACRO LENGHT

VALUE

REPT LENGTH

IFE VALUE – 0FFh

EXITM

ENDIF

VALUE = VALUE + 1

ENDM

ENDM

EXITM – Выход из макроса

Написанный макрос обеспечивает заполнение памяти целыми числами от 1 до 256 байт.

II.

IFDET / IFNDEF имя \_ переменной

Тело выполняется, если определено / не определено имя \_ переменной.

Пример 12. (задает возможность проверки дисплея):

IFDEF Disptest

; часть первой общей проверки дисплея

IFCOLOR

; часть проверки цветного дисплея

ELSE

; часть проверки монохромного дисплея

ENDIF

; часть второй общей проверки

ELSE

; код, выполнения при отсутствие проверки

ENDIF

IFB / IFNB <аргумент> Проверяет, имеется или отсутствует аргумент (IF Blank – если отсутствует)

Применяется:

1. Для выдачи подсказок об отсутствия аргументов.
2. Для разработки рекурсивных макросов с переменным числом в параметрах.

Пример 11.

I способ применения

Make \_ Pasc \_ String Macro Id, Msg

Local MsgLen, Endstr

Ifb <id>

Display ‘Задать переменную id’

ExitM

IFB <Msg>

Display ‘Задать преобразованную строку’

ExitM

Else

Id Db Endstr-id-1,’&Msg&’

Label EndStr Byte

EndIf

EndIf

EndM

II способ применения

PushReg Macro R1, R2, R3, R4, R5, R6

Ifnb <R1>

Push R1

PushReg R2, R3, R4, R5, R6

Endif

EndM

Отличительные признаки рекурсивного вызова макроса:

1. Должен быть вызов заново себя с количеством элементов меньше на единицу.
2. Предусмотрен контроль аргумента с помощью директивы Ifnb.

*Способы использования макросов*

1. Непосредственное размещение макроопределения в тексте программы. (Оно размещается в самом начале, обычно после заголовка.)

Применение:

1. Создание макробиблиотеки с последующим подключением ее к программе. Библиотека строится как обычный файл. В основной файл добавляются следующие команды:

IF1

Include My \_ Maclib

EndIf

Можно исключить некоторые макросы из библиотеки, если они не нужны.

Purge Mac1, Mac2, Mac7